

## **Attachment B—Exhibit List**

- B1 Nordic-1M Design Specification by Vlad Bril et al. Rev. 3.9 (October 20, 1993)
- B2 Live Video Scheme Proposal by Sasha Eglit (June 17, 1993)
- B3 Nordic Activity and Resource Planning by Rakesh Bindlish et al. (July 20, 1993)
- B4 Lab notes from unknown source On Live Video (July 7, 1993)
- B5 Nordic-1M Product Implementation Plan Rev. 10 12/21/98
  - List of NORDIC-1M Activities as of 10/10/93 (marked 11/4/93) (1 page)
  - NORDIC-1M Development Plan as of 10/16/93 (1 page)
  - Features Added Since 10/20/93 and Features Taken out since 12/20/93  
(1 page)
  - NORDIC-1M Development Plan as of 11/04/93 (1 page)
  - List of NORDIC-1M Activities as of 10/10/93 (marked 12/10/93) (1 page)
  - NORDIC-1M Development Plan as of 11/22/93 (1 page)
  - NORDIC-1M Development Plan as of 12/03/93 (1 page)
  - NORDIC-1M Development Plan as of 12/10/93 (1 page)

2025 RELEASE UNDER E.O. 14176

**BEST AVAILABLE COPY**

B1

EXHIBIT

RX-578 C

Cirrus Logic, Inc. Confidential Information

# NORDIC-1M Design Specification

by Vlad Bril, Robin Han, Sasha Eglit, Rakesh Bindlish, Dwarka Partani.

Jeff Ort

rev.3.9 October 10, 1993

## 1.0 Introduction & Table of Contents

Nordic is Cirrus Logic's Fourth Generation Flat Panel VGA Controller to be marketed in first half of 1994.

Nordic-1M is a mid-end member of the Nordic family. It is a GUI Accelerator with PCI support and Multi-Media Features.

Nordic-1M is targeted for the mid to high end of the Note-book Computer Market and for the energy efficient desk-top computers mother-boards.

Nordic-1M is not targeted to the adapter market.

### 1.1 Table of Contents

This Specification will address the following:

1. Introduction and Table of Contents
2. Basic Feature Set
3. Detailed List of Features
4. Pinout and Pin Description
5. Architecture Specification
6. Register Specification
7. Product Implementation Plan

CIRRUS LOGIC CONFIDENTIAL

Cirrus Confidential  
Business Information

CL 146366

DO NOT COPY - PROTECTED MATERIALS

## 2.0 Nordic-1M Basic Feature Set

1. Flat Panel VGA Compatible GUT Accellerator register and feature compatible to 5428 and Alpine I A/V. Priority: A (= highest).
2. 32bit CPU, 32bit Video Memory, 32bit BLT and 32bit CPU to Video Memory Data Path. Priority: A (= highest).
3. 208 pin QFP package.
4. Targeted to sample CY Q1'94, production CY Q2 '94. Priority: A (= highest).
5. Target cost: \$12 to \$10 -> less than 400mil [/] in C8 Foster City.

## 6. Multimedia Features

- Part of a well defined System Solution for high performance CD-ROM video and audio playback for the portable market. Priority: B
- Part of a well defined System Solution for mid performance low cost live NTSC Video and Audio with the NTSC decoder on a PCMCIA card. Priority: B
- Audio Port to Display Memory: Audio Buffer to Serial Interface for CS4248 Audio Codec. Priority: C (CS4215 is not fit for notebook computers).
- Video Playback decompression accelleration for CinePak including Color Space Conversion (YUV -> RGB). Priority: B
- Live Video in a 320x240 or 640x480 Window from a proprietaryly compressed TV decoded data source (at 30Hz) on TFT color panels. Data is stored compressed and it is decompressed to 18bit/pel or 24bit/pel in real time at display time. NTSC decoder and data compressor is on the PCMCIA card or the PCMCIA controller. Please note that due to live video bandwidth requirements on PCMCIA bus , a relatively non-expensive way to achieve the second feature is to implement this compression algorithm. Priority: B
- Color Key Live Video Overlay based on a 5428-like Feature Connector with PCI bus (only).

## 7. Integrated in Nordic 1-M

- Color Space Converter for CinePak. Priority: B
- 18bit DAC with direct color capability Priority: A
- 24bit RAMDAC with true color capability Priority: C
- Clock Synthesizers for Video and Memory Clock (65MHz/3V, 110MHz/4.5V). Priority: A

Cirrus Confidential  
Business Information

CL 146367

**Cirrus Logic, Inc. Confidential Information**

- DAC IRef Current Source on chip. Priority: C. *Boyd and ManShek are working on it.*

**8. Direct Bus Interface:**

- 32bit VESA-VL bus (and 486 local bus) Priority: A
- 32bit PCI bus. No on chip BIOS ROM support in PCI. Priority: A
- 16bit ISA bus for demonstration and easy system validation. Priority: B
- 32K or 48KB BIOS ROM support in ISA and VESA VL bus. Priority: B (only for BIOS/ system debug)
- At least 5 scratch pad registers: optimum 8 scratch pad registers. Priority: A.

**9. Performance Enhancements to achieve 15-20MWinmarks at 1Kx768 8b/pel:**

- 32bit BitBLT with memory mapped I/O BitBLT registers (as in 5428 ?or Alpine) Priority:A
- BLT buffer of 8 (~~or 16~~) bytes for Source (and Destination ?) data, (5428 buffer is 8bytes, Alpine is 16bytes) (as 5428)
- X/Y offset for Pattern BLT (as in Alpine) Priority: C
- h/w graphic cursor 64x64 (as in 5428)
- color expansion (as in 5428)
- linear memory addressing (as in 5428)
- 4 stage 32bit wide write buffer and capability to page CPU cycles if accumulated in the write buffer (this is already in 5428)

**10. Display Memory:**

- 0.5MB (16bit wide), 1MB or 2MB memory addressing 32bit wide (as in 5428)
- 1 or 2 256Kx16 one bank or 4 256Kx16 two banks (2 CAS symmetric, 2 WE asymmetric) (as in 5428)
- maximum memory clock frequency: 50MHz/3V, 65MHz/4.5V Priority: C

**11. Flat Panel Support: [Priority: A]**

- Color TFT (24bit, 18bit, 12bit, 9bit)
- Color Dual Scan and *Single Scan STN* (16 and 8 bit, including dual clock panels)
- Monochrome TFT (8bit),
- Monochrome Dual Scan STN (8bit),
- Monochrome Single Scan (4 and 8bit) support

Cirrus Confidential  
Business Information

**CL 146368**

Cirrus Logic, Inc. Confidential Information

- Simulscan with all Fast Panels (6.3MHz or equivalent) with 32bit wide memory.  
No simulscan with 16bit wide memory with dual scan color panels.  
No simulscan for 3MHz monochrome dual scan panels.
- 640x480 single and dual scan support (Priority:A)
- 800x600 TFT *and no single and dual mono and color STN panel support* (Priority: C)
- 1024x768 TFT *and no single and dual scan STN panel support* (Priority: D)

**12.Display Features**

- High quality monochrome and color shading, at least as good as 6440. Priority: A
- Shading option for fast panels. Priority: B
- Up to 8, 64x64 Hardware Icons independently mapped color+transparent background. **Priority: C**
- *Whisper Cross-Talk Reduction (If panels will be available in the time frame and if we can accomodate it with the shading algorithm). Priority: C*
- *"Office Productivity Booster Dual Display" 640x480 (panel) & 640x480 (CRT) 4 or 8b/pel or 640x480 (panel) & 1024x768 (CRT) 4 or 8b/pel Priority: E*
- Vertical Expansion in text and graphics (as in 6235 or 6440)
- Automatic Centering if not expanded (as in 6235)
- *Grey-Shades Maping options ?? Is this needed ? Priority: D*
- Text Contrast Enhancement options. (as in 6235 or 6440)
- *Inking Plane ?? Priority: D*
- *180 and 90 degree image rotation ?? Priority: D*
- *12 and 16dots wide font support ?? Priority: D*
- *h/w offset on h/w cursor ?? Priority: D*

DO NOT DISTRIBUTE

**13.Resolutions Supported:**

- the same as 5428 at 5V (4.5Vmin)
- up-to 45MHz dotclk (1024x768, 60Hz interlaced) at 3.3V

**14.Power Management**

- Mixed 3.3V and 5V operation: memory, host and flat panel independent VDD
- Green-PC spec support. **Priority: B**
- Stand-by Mode with internal stand-by timer (as in 6235)

Cirrus Confidential  
Business Information

**CL 146369**

NORDIC-1M DESIGN

## Cirrus Logic, Inc. Confidential Information

- Suspend Mode I/O or pin in all modes (LCD, CRT, Simulscan)
- *Light Sleep ?? - better not for this chip as it requires too much h/w. Priority: F*
- Panel Power Sequencing: automatic or under I/O control (as in 6235)
- Reduced Active Power in Panel Only Operation: < 60mAmp @3.3V. Priority:A
- Reduced Suspend Current: < 0.5mAmp. Priority: A

### 2.1 Inputs from the Nordic-1M Features Meeting of 09/10/93

- 24bit DAC if not too expensive (VAR)
- mclk @5V max 65MHz, @3V max 50MHz
- vclk and fpvdcclk @5V max 85MHz, @3V max 65MHz
- panels:
  - TFT 1280x1024? ##, 1kx768 ##, 800x600 ##, 640x480  
24bit, 18bit, 12bit, 9bit color, 6bit mono  
NEC analog output? ##
  - STN 800x600 dual scan color, 640x480 ds color 16bit  
640x480 ss color 8bit  
640x480 mono bit 8bit and 4bit
  - horiz ## and vertical centering
  - normal 9dot font in 800x600 text ##
  - simulscan for 800x600 and 1kx768 panels ## (need to run all modes at 800x600 or 1024x768 resolutions -> option to clock panel till h&v Blank )
  - support for two alternate fonts 10x24 for 800x600 (10x18 actual with spacing) and 12x25 for 1kx768 ## difficult !!
  - h&v text expansion in 800x600 and 1kx768 panels ## ?
  - color text enhancement ## : bright white instead of white
  - on chip cross-talk reduction ## ? - any improvement ?
  - shading look-up tables ## ? - only if not too large
- NO Whisper support even on the bus side - out !
- NO one 256Kx16 DRAM support - out !
- h/w icon support: with h/w cursor, up to 4 simultaneously. Horizontal position controlled in increments of 64 pixels.  
Icon attributes: off/on, 4 colors/3colors + transparent, no\_blink/blink. (simple/double).  
H/W cursor goes over the h/w icon (visually). Uses independently mapped color in RAMDAC RAM. Start at scan-line 64.
- PC98 integration? ## - to be negotiated
- reserve pins for SDRAM-s and CDRAM-s ##
- NO true dual display!

Cirrus Confidential  
Business Information

### 2.2 Inputs from Compaq 09/10/93

- 50MHz 486DX bus
- 75Hz refresh rate
- need one 256Kx16 support with Audio and some video for Contura - build one motherboard for Contura and LT Lite. Two DRAM-s only on LT Lite.

CL 146370

Cirrus Logic, Inc. Confidential Information

- think that 8KB/buffer of audio buffer is not enough
- want to use Analog Devices for Audio
- No clear winner on compression. They are watching. Need Indeo driver.
- Play-back zoom is required. At least pixel replication.
- Very interested in Compressed Live Video. Want to talk more.
- need h/w icon 64x64 with 3col+transparency or 4 color, with pixel replication to 128x128.

**2.3 Inputs from AST 09/15/93**

- They prefer horizontal icon

**2.4 New Features as of 10/04/93**

- 4bit/pel packed support for Windows Chicago
- 8bit/pel video out to the Feature Connector for conversion to NTSC-out with Nordic running 640x480 interlaced mode.  
Another idea was to use some of the panel outputs in this case and extend the data out to 16bits.
- The h/w icon can be horizontal or vertical using the Motion Video Window as implementation vehicle -> is it worth?
- IBM Raleigh asked for 12 and 16dots wide fonts for h/w assisted Kanji. 10/04/93
- IBM Raleigh asked for 8bit monochrome TFT panel support. 10/04/93

**3.0 Important Additions to 5428 Data Base**

1. 32 bit CPU Data bus in VESA VL bus support
2. PCI bus support
3. Mono and color, STN and TFT Flat Panel support (incl. hsb).
4. Live video in a true color window with Windows running in planar VGA mode, without a video port (using PCMCIA standard bus and Sasha's decompression technique).
5. CINE PAK decompression acceleration
6. Audio Port support for CS4215
7. Power Management: panel power sequencing, stand-by mode, suspend mode
8. Mixed Voltage, 3.3V operation and low active/suspend/standby power
9. h/w icon support, with a h/w cursor support
10. BLT performance improvements: Memory Mapped BLT I/O, patterning, 16 byte Source buffer

Cirrus Confidential  
Business Information

11. *[dual display 1024x768 on CRT with 640x480 on LCD, using the same RAMDAC] - if decided to do now*

## 4.0 Detailed List of Features

### 4.1 WAS: On the Cross Talk Reduction Technique -> not in -1M

This part was deleted from Nordic-1M spec starting rev. 3.8 (09/11/93).

### 4.2 Green PC Spec Support (Based on VESA DPMS Proposal 1.0p rev. 0.53p)

This specification refferes to CRT Monitor power management. Additionally, Nordic will

**TABLE 1. Display Power Management Summary**

| State        | H SYNC    | V SYNC    | Video RGB | Compliance | Power Savings | Recovery Time     |
|--------------|-----------|-----------|-----------|------------|---------------|-------------------|
| CRT On       | Pulses    | Pulses    | Active    | Mandatory  | None          | NA                |
| CRT Stand-by | No Pulses | Pulses    | Blanked   | Optional   | Minimal       | Short             |
| CRT Suspend  | Pulses    | No Pulses | Blanked   | Mandatory  | Substantial   | Longer            |
| CRT Off      | No Pulses | No Pulses | Blanked   | Mandatory  | Maximum       | System Dependednt |

control DAC power consumption. These power management CRT Monitor states are not necessarily related to the graphics controller power management states.

We'll define 2 bits - GRE[2:1] (the same as Alpine) that control HSYNC, VSYNC and DAC Power Off signal (or Blankn to the DAC).

Cirrus Confidential  
Business Information

CL 146372

TABLE 2. GRE[2:1] Effect

| GRE[2:1] | CRT State | Vsync                            | Hsync                            | DAC Power | Nordic Power Management State |
|----------|-----------|----------------------------------|----------------------------------|-----------|-------------------------------|
| 0        | On        | pulsing                          | pulsing                          | on        | active                        |
| 1        | Stand-by  | pulsing                          | static at MISC[6] inactive level | off       | active                        |
| 2        | Suspend   | static at MISC[7] inactive level | pulsing                          | off       | active or stand-by            |
| 3        | Off       | static at MISC[7] inactive level | static at MISC[6] inactive level | off       | active, stand-by or suspend   |

If Nordic is in its own Suspend mode, the BIOS should program GRE[2:1]=3 to put the monitor (if any) in the Off state.

If Nordic is in its own Stand-by mode, CRT Suspend mode should be forced by the h/w, as stand-by is a timer driven mode and no s/w gets to play.

If Nordic is in LCD only, the BIOS should set GRE[2:1] to 3 to power off the CRT that may be connected to the notebook computer.

If CRT only mode and CRT is in stand-by or suspend, the BIOS may reduce the video clock and even memory clock frequencies after saving the current values.

Except for the above restrictions, CRT Power Management modes are not related to Nordic power management modes: they can be independently programmed.

If MISC bit is programmed for positive polarity, the SYNC signal will be stopped L. otherwise it will be stopped H.

#### 4.3 Play-back Decompression Accelleration (applicable to Cinepak as well as other compression standards) - old, kept here only for reference

##### 4.3.0 The problem

Cirrus Confidential  
Business Information

## Cirrus Logic, Inc. Confidential Information

a) When playback data is compressed on a CD ROM, it is encoded in 24bit/pel YUV with chrominance sub-sampling. Due to CDROM reduced bandwidth the display window is 160x120 or 320x240. If this compressed data is decompressed at full pixel depth, it should be displayed as 24bit/pel RGB window under MS Windows. As the play-back data is sent to the graphics controller from the CPU bus, it has to be placed in Video Memory in 320KB.

A standard VGA controller or even GD5428 are able to display the 24bit/pel play-back window only if MS Windows is run in 24bit/pel mode (for instance 1024x768 24bit/pel or 640x480 24bit/pel) by the driver. Under these conditions, the CPU will have to write the un-compressed 24bit/pel play-back data in the appropriate position in Video Memory, contiguous to the entire displayed data.

So, in order to display 24bit/pel in a play-back window, GD5428 needs the driver to run 24bit/pel at the maximum display resolution.

But, in order to run 640x480 at 24bit/pel we need 921.6KB of Video Memory and in order to run 1024x768 24bit/pel we need 2359.296KB of video memory. (Please note that 2M of memory has 2097.152KB).

Also, when running windows in 24bit/pel mode the performance will decrease 3 or 4 times relative to 8bit/pel mode, especially when using DRAM as Video Memory.

b) When running through MS Windows GDI, the driver can play-back data at 15fps or less (with a 486 33MHz). It is desirable to play-back data at 30fps.

This can be accomplished today only if the driver does not go through GDI.

c) If a picture was stored on CDROM at low resolution (160x120 or 320x240) and it needs to be "zoomed", it has to be interpolated both horizontally and vertically for good picture quality. Vertical interpolation is expensive in h/w.

Cirrus Confidential  
Business Information

#### 4.3.1 The Generic Solution - old, here for reference only

Today's Windows Accelerators run MS Windows, including the play-back window with the same pixel depth (8bit/pel), normally going through the RAMDAC, but using a split palette approach with 16 colors reserved for MS Windows and 240 colors reserved for the play-back window. The Cinepak driver writes data in video memory in 3:3:2 RGB format

(8bits/pel) which is created by the driver. Because of the s/w overhead involved in decompression as well as the GDI overhead, it is hard to go beyond 320x240 clips at 15fps, though the display quality is much lower than what Cinepak could achieve (240 colors versus 16 million colors).

To run Cinepak with 24bit/pel resolution, today's graphics controllers would require to run MS Windows in 24bit/pel mode, requiring almost 1MB in 640x480 and over 2MB-s in 1024x768 modes.

Cirrus Logic, Inc. Confidential Information

A graphics controller that could run MS Windows in 8 or 16bit/pel mode while displaying only the play-back window in 24bit/pel mode would increase significantly picture quality without degrading too much MS Windows performance with play-back. would reduce significantly the amount of Video Memory required for the same picture quality and would allow a higher frame rate for the play-back.

Further, if the play-back data is stored in Video Memory in a semi-compressed format that requires less than 24bit/pel this would further decrease the Video Memory requirements and it may even reduce the video memory band-width requirements.

When zooming the play-back window from 160x120 to 320x240 or higher it is important to interpolate. Vertical interpolation can be done in s/w but with a relatively large overhead. It may be possible to do vertical interpolation on key frames, but there is no practical way of doing vertical interpolation on inter-frames either in s/w or with h/w assist on the CPU write side of the graphics controller. If s/w driven vertical interpolation on key frames is not a solution, then vertical interpolation can be only achieved in h/w on the CRT read side and this requires either one or two 16bit/pel line buffers or a big penalty on video memory bandwidth (the equivalent of reading 32 or 48bits/pel).

Horizontal interpolation can be done before play-back data is displayed, without s/w help.

Please note that there are multiple ways to solve the play-back problems. In Nordic-1M we'll try to strike a balance between the complexity of the h/w solution and the quality of the play-back image.

To a large extent, the solution adopted in Nordic-1M will be generic, not tied to Cinepak, though it will be first applied to Cinepak.

#### 4.3.2 Nordic-1M old Play-back Acceleration Solution -> canned, kept here for reference

a) Nordic-1M will run Cinepak at 1:1 scale exactly the same way as today's graphics controllers: in 8bit/pel MS Windows with 8bit/pel (3:3:2 RGB) play-back window.

b) Nordic-1M will run 1:2 scale (zoom) in 8bit/pel 1024x768 MS Windows with 24bit/pel (8:8:8 RGB) pixel depth in the play-back window, horizontally interpolated and vertically doubled. Play-back data will be stored in video memory as 16bit/pel (Y0 U01 Y1 U01 ).

c) Nordic-1M will run at 1:1 scale in 16bit/pel 1024x768 MS Windows with 24bit/pel pixel depth in the play-back window. Play-back data will be stored in video memory as 16bit/pel (Y0 U01 Y1 U01 ). This mode is good for programs that store data in 320x240 format.

Because today large play-back windows look bad, while small ones look OK, this solution will improve picture quality to a large extent.

Cirrus Confidential  
Business Information

**Concerns:**

Many play-back programs today don't even have a zoom option. To this extent, mode "b" may not be needed.

Mode c could be implemented today with 16bit/pel RGB (555) in s/w and the only improvement we provide is 24bit/pel capability and h/w color conversion (some level of acceleration). So mode "c" may not be needed as a special h/w.

**If this is the case, maybe we do not need to do anything in h/w for Cinepak !**

One idea: should we run 24bit/pel MS windows stored in 4:2:2 (Y0 U01 Y1 U01 ) format? This will allow us to run 24bit/pel MS Windows and use 16bit/pel memory space with no loss of quality. The windows driver could compress the data and the h/w could decompress it.

0000000000000000

## 4.4 Nordic-1M Motion Video Architecture

### 4.4.0 The Problems to Solve & Generic Solutions

Nordic-1M is supposed to support CDROM play-back and live-video under Microsoft's Video for Windows. With all of today's VGA Compatible Graphics Controllers, the play-back picture pixel depth has to be the same as the surrounding MS Windows pixel depth. In other words, we have to run MS Windows in a 24bit/pel mode in order to display 24bit/pel in the play-back window.

The only way we can run today live video is from a Video Port (= Feature Connector). In this case we'll use an overlay or a color key to define the live video window.

Due to CDROM player, s/w interface complexity, CPU bus and Video Memory limitations, only small clips at 15fps or less can be playd-back today. So today we need a lot of Video Memory to run small clips in slow motion at low rezolution. Nordic-1M will try to use less Video Memory, increase the clips size, their resolution and speed.

**Nordic-1M is supposed to support:**

- accelerated play-back for all popular CDROM compression standards, especially Cinepak and Indeo
- live video from a PCMCIA card in a system with a standard PCMCIA host adapter, for a "Multimedia-Ready Notebook Computer"
- live video from a Feature Connector, preferably VESA Advanced Feature Connector compatible, for a Multimedia Notebook Computer with direct NTSC input (full motherboard solution).

**What will Nordic-1M bring to the Video plate:**

**Cirrus Confidential  
Business Information**

- A. Nordic-1M will break the dependency between the pixel depth of MS Windows and the pixel depth of the live-video / play-back window. By doing so, Nordic-1M will be able to run 24bit/pel LV/PB while running MS Windows in 8bit/pel or 4bit/pel (even planar). This will lead to high quality live-video and play-back, while minimizing Video Memory requirements.
- B. Nordic-1M will further reduce Video Memory requirements as well as Video Memory Bandwidth requirements by storing data in compressed form: 4:2:2 YUV (16bit/pel), 4:1:1 YUV (12bit/pel) or Sashapak YUV (2.6bit/pel)
- C. Nordic-1M will define one architecture and work-frame to run both play-back and live-video in a unitary way for both s/w and h/w.
- D. Nordic-1M will support up to two active LV/PB windows at the same time.
- E. By providing h/w YUV->RGB conversion and 1:2 zoom Nordic-1M will accellerate playback for most standards, but mostly for standards that allow us access to their decompressor like Cinepack (for whose decompressor we have a licence).

Nordic-1M will not provide Cinepak specific accelleration (custom BLT).

#### On the Live Video from Feature Connector (or Video Port)

Due to pin-out limitations, the VAFC implementation has to be limited to 8 pins of data requiring external muxing of 16bit data to Nordic. Further, the VAFC solution will be restricted to 5428 type support: overlay and color key (no memory video port). The only additions to the 5428 support will be the internal YUV-> RGB converter able to accept sequential 4:2:2 YUV (16bit/pel in average: Y0,U,Y1,V) and display it as a 24bit/pel RGB in the overlay/color-key window. We may also support horizontal 1:2 zoom with averaging. Nordic-1M will be back-wards compatible to 5428 and it will support also 16bit 5-5-5 RGB Sierra and 5-6-5 RGB XGA pixel formats. As in 5428, live video from the Feature Connector can be executed only from mode 5F (640x480 256 colors).

In the following we will refer mostly to the other two modes of operation: play-back and live video from a PCMCIA card, which we'll call compressed live video, because due to PCMCIA bus bandwidth limitations, we assume that video data received by Nordic is compressed with Sashapak (see Sashapak details further in this spec). Please note that due to its huge advantages, it makes sense to use Sashapak as a mother-board solution too. The main reason we continue to support the Feature Connector based live video is the availability of drivers for 5428 which will give Nordic an early start in the live video arena.

#### Video Memory Band-width Constraints

Please note that, even with a 32bit wide Video Memory, there are severe memory band-width limitations when running 16bit/pel and 24bit/pel graphics modes.

Assuming that Nordic-1M does 8 CRT fetches in a row and 1 CPU cycle, for a CRT or TFT panel, here are the minimum frequency requirements for memory clock frequency at different resolutions and pixel depths:

24bit/pel:

R+7P+R=12m+14m=26m with 1 CPU cycle per CRT FIFO fill fetches data for  
32B/3B=10pixels

Cirrus Confidential  
Business Information

R+7P = 6m+14m = 20m with no CPU cycle during non-display time  
min mclk freq = 65MHz / 50MHz @ 640x480 -> Nordic-1M upper limit at 5V CVDD  
= 104MHz / 80MHz @ 800x600 -> too high  
= 169MHz / 133MHz @ 1024x768 60Hz -> too high

16bit/pel:

R+7P+R=12m+14m=26m / R+7P = 20m fetches data for 32B/2B=16pixels  
min mclk freq = 40.6MHz / 36MHz @ 640x480 -> OK even at 3V  
= 65MHz / 50MHz @ 800x600 -> Nordic-1M upper limit at 5V CVDD  
= 105MHz / 83MHz @ 1024x768 60Hz -> too high

12bit/pel:

R+7P+R=12m+14m=26m / R+7P=20m fetches data for 32B/1.5B=21pixels  
min mclk freq = 30.9MHz / 23MHz @ 640x480 -> OK even at 3V  
= 49.5MHz / 380MHz @ 800x600 -> OK even at 3V  
= 80.4MHz / 64MHz @ 1024x768 60Hz -> too high

8bit/pel:

R+7P+R=12m+14m=26m fetches data for 32B/1B=32pixels  
min mclk freq = 20.3MHz @ 640x480 -> OK even at 3V  
= 40.6MHz @ 800x600 -> OK even at 3V  
= 52.8MHz @ 1024x768 60Hz -> OK at 5V

We may conclude that Nordic-1M will be able to run 24bit/pel only at 640x480 rezolution, 16bit/pel up to 800x600, 12bit/pel up to 800x600 and 8bit/pel up to 1024x768 rezolution. These results apply only to CRT or TFT and single scan STN panels.

Please note that for dual scan STN panels the memory requirements increase significantly.

These severe memory bandwidth limitations lead us to attempt to minimize video memory traffic. If we store Cinepak data in 4:2:2, with an avarage of 16bit/pel, independent of Cinepak window size, Nordic-1M will not be able to run Cinepak above 800x600. Any attempt to execute vertical zoom with interpolation, even with two points interpolation will further aggravate this memory band-width bottleneck. The next step should be 100MHz SDRAM-s with a large CRT FIFO (32x32) or 64bit wide memory data bus. These considerations apply to any playback compression standard that stores data in video-memory as 16bit/pel in avarage. The key to a successful compression standard would be one that does decompresssion on the CRT memory read and stores data in memory as 8bit/pel or less, in avarage.

As we store live video at 2.6bit/pel and fetch it as if it was 8bit/pel with Sashapak. Nordic-1M should be able to run live video even at 1024x768.

If we defined a new CDROM play-back standard based on Sashapak, then we could run even 1024x768 with 24bit/pel accuracy and keep it memory as an 8bit/pel. Keith and Ken are actually working on it, with Sasha's help.

Cirrus Confidential  
Business Information

#### 4.4.1 On Sashapak

Sashapak is a highly assymetric, lossy "Block Truncation" compression algorithm optimized for visually equivalent image processing.

Data is proccessed as Y,U,V one byte each. U and V are sub-sampled, characterizing one 8

Cirrus Logic, Inc. Confidential Information

by 8 pixel array, while Y is characterizing a 4x4 pixel array. Actually one of two values is assigned to each pixel inside the 4x4 (for Y) and 8x8 (for U and V).

At compression time, the compression chip determines a threshold and two values U&L for each group of sixteen (4x4) pixels. This way all pixels above threshold will be assigned the value U, all pixels below threshold will be assigned the value L.

|                                                                 | 31 | 1byte | 1byte | 2bytes | 0 |
|-----------------------------------------------------------------|----|-------|-------|--------|---|
| 4                                                               | Y0 | U     | L     | BITMAP |   |
| 4                                                               | Y1 | U     | L     | BITMAP |   |
| 4                                                               | Y2 | U     | L     | BITMAP |   |
| 4                                                               | Y3 | U     | L     | BITMAP |   |
| U,V                                                             |    | U     | L     | BITMAP |   |
| 64pixels are described by<br>6x4B=24B=192bits<br>=> 3bit/pel    | U  | U     | L     | BITMAP |   |
| Using 6bits for U & L<br>the compression will be<br>2.6bit/pel. | V  | U     | L     | BITMAP |   |

At decompression, the bitmap will control a mux between the U and L values. This way the decompression is straightforward.

The main drawback of this approach is that a BITMAP contains Y data from 4 scan lines and U,V data from 8 scan lines. When data is read from memory to be displayed only data from one scan line is used. Similarly the U/L values apply to several scan-lines and the same value will be read in each scan line. The same data will be read again and again in each scan line raising the actual memory bandwidth requirements to an equivalent of 16bit/pel map.

In order to overcome this problem and reduce memory bandwidth requirements. Sasha proposed a scan line oriented, segregated mode of data organization. This would require the Sashapak compression chip to write compressed data in a specific way putting the strain on the compression chip address generator. The basic principles of the new organizations are:

1. Data is organised in the MV Window in chunks of 32 sequential pixels.
- a) For 8bit U/L resolution, as one Y covers 4 pixels. 8 U/L sequential values are needed. 16bits each ->  $8 \times 16 / 32 = 4W$  ( $8 \times 12 / 32 = 3W$  for 6bit res. U/L) (where W is a 32bit word).
- b) U and V U/L data is packed together in the same word (16bits for U U/L and 16 bits for V U/L -> total 32bits=1W) and as one pair of U and V applies to 8pixels. 4 such values are needed for 32 sequential pixels ->  $4 \times 32 = 4W$ . ( $4 \times 12 \times 2 / 32 = 3W$  for 6bit res. U/L)
- c) The mask data is also scan-line oriented: all 32bits of Y mask of sequential 32pixels are placed in one 32bit word and due to sub-sampling on U and V, all 32bits of U and V mask of sequential 32pixels are placed in one 32bit word. So in 2W data for 32 sequential pixels on one scan line is packed. -> 2W (the same for 6bit resolution for U/L)
- d) For 640x480 window size, even at 8bit U/L resolution, data for 8 scan-lines fits in one DRAM page (symmetric DRAM-s assumed):  $320WY + 80WU + 80WV = 480W < 512W$  page

Cirrus Confidential  
Business Information



f) The key to memory bandwidth optimization is the fact the the compression chip will organize data sequentially over 32 pixels instead of 8. This will be done for the mask bits which will be organized sequentially by scan line and for the U/L data. This way a 32bit word of Mask data contains only information for the current scan line and no extra memory fetches are required. The main reason we segregate U/L for Y and U/V is the fact that we want to use 6bit U/L. In this case it is easier to identify the proper U/L info chained within 32bit words if the words are sequential and we have a fix relationship between their address and the 6bit U/L quantities.

- g) If we calculate now the amount of data we need to fetch to display 32 sequential pixels:
- for 8bit per U/L: 4W (YU/L) + 4W (UV U/L) + 1W (YM) + 1W (UVM)=10W=40B  
--> 40B/32pixels=320bit/32pixels=10bit/pel to fetch from memory
  - for 6bit per U/L: 3W (YU/L) + 3W (UV U/L) + 1W (YM) + 1W (UVM)= 8W=32B  
--> 32B/32pixels = 8bit/pixel

This is a very good data fetch ratio, much better than the 16bit/pel we'd get without the optimization.

g) When reading data from the Motion Video Window the controller will generate the following sequence of addresses, all of them in the same DRAM page (8bit per U/L):

- fetch the YU/L for the first 32 pixels on scan-line n at addresses:  
MVW\_Start+n\*MVW\_Offset, +1, +2, +3
- fetch the UV U/L for the first 32 pixels on scan-line n at address:  
MVW\_Start+n\*MVW\_Offset+A0h, +1, +2, +3
- fetch the Y BitMap for the first 32 pixels on scan-line n at address:  
MVW\_Start+n\*MVW\_Offset+F0h
- fetch the UV BitMap for the first 32 pixels on scan-line n at address:  
MVW\_Start+n\*MVW\_Offset+190h
- fetch the YU/L for the first 32 pixels on scan-line n at addresses:  
MVW\_Start+n\*MVW\_Offset+4, +5, +6, +7
- fetch the UV U/L for the first 32 pixels on scan-line n at address:  
MVW\_Start+n\*MVW\_Offset+A0h+4, +5, +6, +7
- fetch the Y BitMap for the first 32 pixels on scan-line n at address:  
MVW\_Start+n\*MVW\_Offset+F0h+1
- fetch the UV BitMap for the first 32 pixels on scan-line n at address:  
MVW\_Start+n\*MVW\_Offset+190h+1
- now the MVW FIFO is full.
- chunks of ten 32bit words will be proccessed for every 32pixels displayed
- the MVW FIFO gets empty after the first 10 words being read for decompression and display.

Please note that all data for every 8 scanlines starting from the top of the MVW is in the same DRAM page.

Because we have to fetch the MVW Data before we start displaying it, and because at that

Cirrus Confidential  
Business Information

time the CRT FIFO does not empty as fast as it is needed (unless MS Windows is running at the same pixel depth as the MV Window), it is necessary to have a separate FIFO for the MVW or at least half the FIFO (at least 10W for 8bit per U/L and at least 8W for 6bits per U/L).

h) When we run 6bit per U/L, because the Video Memory band-width requirements are as if we were running 8bit/pel, we could do vertical zoom with avaraging. But there should not be a need for zoom with Live Video because there is enough CPU and memory band-width to run 640x480 windows even when MS Windows is run as 1024x768 4 or 8bit/pel.

**Conclusion:** With Sashapak we can get data organized in memory such that the memory bandwidth is as for 10bit/pel (8bit U/L) or 8bit/pel (6bit U/L) pixel depth. The actual memory area will be close to 3bit/pel or 2.6bit/pel depending on the resolution of U/L values - 8 or 6bits per value.

Please note that the memory area will be slightly larger due to the fact that we use only 480 words in a page of 512.

#### 4.4.2 YUV to RGB Conversion Algorithm

The ideal YUV to RGB transformation is:

$$R=Y+1.37V$$

$$B=Y+1.73U$$

$$G=Y-0.699V-0.336U$$

After defining an objective way of measuring color error, Sasha came up with the following Conversion algorithm:

$$R=Y+1.375V=Y+1 \frac{3}{8} V$$

$$B=Y+1.75U=Y+1 \frac{3}{4} U$$

$$G=Y-0.375U-0.75V= Y-(\frac{3}{8}U+\frac{3}{4}V).$$

This algorithm can be implemented with 8 9bit adders.

#### 4.4.2 Motion Video Architecture Functional Blocks

Instead of treating play-back and live-video as two separate modules, we'll isolate several generic functions to be used by both:

Cirrus Confidential  
Business Information

- Display Window Generation Block:

allows s/w to define one or two play-back or live video window(s).

The MV Window is defined in 4bit/pel equivalent CRT Addresses:

- MVW Start Address (19bit)
- MVW Width (max 640pixels => 80 addresses) -> CRT address after MVW on each scan line.
- The number of memory cycles to be executed at MVW pixel depth on each MVW scan-line (max 320 cycles for 16bit/pel storage at 32bit/pel pixel depth) -> scan line end.
- MVW OFFSET to the start of the next MVW Scan Line (19bit)
- MVW End Address (19bit) or MVW number of scan-lines (9 bits).

Scan-line doubling for "zoom" should be taken into account when designing DWG.

- Off-screen MV Memory Addressing and Access Control. This includes data type tag generation based on MV memory Address and the circuitry placing the tags in the CRT-FIFO. This also includes the MV prefetch cache that makes sure that there is enough prefetched MV data before starting and MV scan line display. This block has provisions for scan line replication by repeating the MV address generated on the previous scan line of the MV window (only).
- One tag bit is generated based on CRT Address and is 1 if the data in the CRT FIFO and the pre-fetch buffer is from the MVW, other-wise is 0. This tag bit, called the steering bit will be delayed through the entire data path and end up controlling the final video data mux just before the DAC
- MV Data Path and CRT-FIFO Control. This is area wise the largest piece. It consists of a new 16bit wide data-path with the same delay as the VGA data path, that takes MV data from the MV prefetch cache and the CRT FIFO, treats it appropriately depending on the MV data format encoded in the MV tags and converts it to 24 bit YUV first and 24bit RGB second. Horizontal zoom with avaraging (or maybe 5 levels of interpolation) is in this block too.
- Pre-fetch MVW Buffer - is needed in order to pre-fetch scan line data for the Motion Video Window every scan-line. Because the MS Windows pixel depth and MVW pixel depth don't match, it is necessary to fill in a separate buffer every MVW scan line before the CRT-Address Counter reaches the window boundary. The buffer will be filled first during vertical non-display time and later after each MVW scan-line display. For Sashapak this buffer has to store data for 32pixels (10x32bit for 8bit per U/L or 8x32bit for 6bit per U/L). This function can be implemented as a dinamic size modification in of the CRT-FIFO. If the CRT-FIFO has 24 stages instead of 16 but only 16 stages are used before the MVW but it is switched to 24 when MVW fetches start, there will be 8 more stages to fill at that time ensuring more prefetched data in the CRT-FIFO at the beginning of each MVW scan-line.
- Steering logic decode the tags comming out of the special addition to the CRT-FIFO and the pre-fetch buffer and controls the decompression, formatting and serialization. (they tell the formatter what data is Y, U or V).
- While switching to display the MVW the CRT Address counter continues to count at the pace set by the graphics mode outside the MVW (4 or 8 bit per pixel normally). The counter contents is compared with the MVW boundaries to detect the end of the MVW.
- What about the video serializer load and the CRT FIFO read signal? What hapens to them when in VMW? They are one signal today. WHEN the data path switched to display VMW data, what hapens with the VGA Video Data Path is don't care as we do not display that data, except for the h/w cursor and the h/w icon that do not go through the standard VGA serializer. So we'll probably stop the VGA data path until the point h/w cursor and h/w icon are combined into it, to save power, as we will stop the VMW data path when not in use, for the same reason.

**Cirrus Logic, Inc. Confidential Information**

So, the Video Serializer Load may be stopped while VMW data is displayed, but the CRT FIFO read will be going on, with a frequency and shape depending on the data format loaded in the CRT FIFO for display.

At the beginning of each VMW scan-line, the CRT-FIFO signal read will be applied only to the pre-fetch buffer and not to the CRT-FIFO itself (the CRT-FIFO read pointer won't change). Subsequently, when the pre-fetch buffer is empty (format dependent), the CRT-FIFO read will be applied to the CRT-FIFO read pointer after the data the pointer is pointing to was loaded into the VMW formatter and serializer.

In RGB 3:3:2 8bit/pel direct color mode CRT-FIFO read will be generated every 4 vclks. In standard RGB 5:5:5 or 5:6:5 16bit/pel modes CRT-FIFO read will be generated every two vclks.

In YUV 4:2:2 24bit/pel (Y0 U Y1 V on one scan line) the CRT-FIFO read will be generated also every two vclks.

IN Sashapak 10 (for 8bit per U/L) or 8 (for 6bit per U/L) CRT-FIFO read pulses will be generated every 32 vclks.

- The VMW Address Counter, loaded at the beginning of each VMW scan-line with a start address calculated based on the Start VMW Address and the VMW Address Offset, will count at format dependent rate for as long as the CRT-FIFO is not full. Because the CRT-FIFO will be emptied faster in the VMW (in general the pixel depth will be higher in the VMW) there will be requests for more memory cycles when displaying in the VMW.

- If either h/w cursor or h/w icon are on, they should be displayed even if the direct data path is used. In this case both video data paths will clock and the steer tag will point to the VGA data path when either h/w cursor or h/w icon or both are displayed, even on top of a MV window. Please note that neither the h/w cursor, nor the h/w icon data go through the CRT FIFO or the VGA Data path except for the final pixel address block and the RAMDAC RAM, though they have a special path in the RAM. So we could stop most of VGA data path (including the internal palette) but not all of it even if we are in 16bit/pel mode (the new one that goes through a separate 16bit data path).

- If we are in a 16bit/pel mode with no h/w cursor or h/w icon, or in a 640x480 MVW mode filling the screen, we can stop the VGA data path to save power.

- The off-screen MVW memory will be a fix memory array towards the end of the memory, but before h/w cursor, h/w icon and the half frame buffer, even the color one. The start of the MVW memory will be fix for a memory size but it will be moving with the memory size: **2MB configuration will support enough memory to support:**

- one 640x480 3bit/pel window or up to two 320x240 3bit/pel (Sashapak) -> 32KW
- one 640x480 16bit/pel window or two 320x240 16bit/pel windows

( $153.6\text{KW} = 614.4\text{kB}$  out of  $256\text{KW}$  or  $512\text{KW}$  available depending on the memory configuration).

- all of the above at the same time up to a total of two windows though.

**1MB configuration will support:**

- one 640x480 3bit/pel Sashapak window or two 320x240 Sashapak windows or
- two 320x240 16bit/pel windows.

In general, the MVW off-screen memory start address is fix, but it can grow into hfb memory if there is no hfb.

**Cirrus Confidential  
Business Information**

**Cirrus Logic, Inc. Confidential Information**

*We may decide to place the start of the MVW memory array at either one of two locations to optimize for TFT panels versus STN color.*

Please note that about 56KW are needed for 800x600 DS Color STN HFB, the h/w cursors and h/w icons while about 36KW are needed for 640x480 DS Color STN HFB and that:

- 640x480 4bit/pel requires 38.4KW
- 800x600 4bit/pel requires 60KW
- 1024x768 4bit/pel requires 98.3KW
- 640x480 8bit/pel requires 76.8KW
- 800x600 8bit/pel requires 120KW
- 1024x768 8bit/pel requires 196.608KW

**Video Motion Formats supported are:**

- 8bit RGB not going through the palette (RGB 3:3:2)
- 16bit RGB (5:5:5 Sierra and 5:6:5 XGA) not going through the palette -> this is a 16bit/pel that does not require double dotclock !!
- 4:2:2 YUV Y0,U,Y1,V for Cinepak (or 4:1:1 if proven more useful)
- Sashapak format (Y0-ULM, Y1-ULM, Y2-ULM, Y3-ULM, U-ULM, V-ULM)

The tags that accompany the motion video data through the CRT-FIFO mark both the data format and the type of data inside the format (U/L for Y or U,V or mask for Y or U,V in Sashapak, Y0, Y1,U or V in 4:2:2).

**Note:** It may prove simpler to design a system in which the MVW is defined on the Horizontal and Vertical Counters instead of the CRT-Address. In this case, for the system to be simple we should fetch both normal CRT data and MVW data on the scan-lines on which there is MVW data. Other-wise we have to prefetch CRT data during the window.

The system would have two separate FIFO-s. A MVW will be detected during the horizontal non-display time of the previous scan line and a MVW FIFO fill will occur. Once the MVW FIFO is empty, a refill will be in order. The CRT FIFO will be refilled before the MVW ends unless the CRT FIFO cycles continue normally during the MVW, which requires a lot of memory bandwidth.

**Cirrus Confidential  
Business Information**

**CL 146384**

20000427-202400



DO NOT EDIT - THIS IS A CONFIDENTIAL DOCUMENT



## 4.5 Feature Connector Support

Nordic-1M will support 5428 Feature Connector so that it is compatible to Media Manager.

Nordic-1M will support VAFC (Vesa Advanced Feature Connector) in the 8bit VSVPC passthrough compatibility mode.

The main difference between 5428 FC and Nordic FC is the fact that 5428 FC has one EDCLKn control pin controlling the direction of the DCLK pin, while Nordic-1M as well as VAFC have a FCDCLK output pin and a FCVCLK input pin.

Dave Keene believes that 5428 FC is VAFC compatible. To ease the design, I kept 5428 FC pin names (not VAFC pin names).

On VAFC compatibility here are some comments:

- GENCLK can be applied on XVCLK if SR22[3]=1.

But, if SR22[3]=1 (select xclk) & SR24[7]=1 (VAFC enabled), then XMCLK should get OSC and MCLK Synthesizer operates normally, except that the reference frequency comes from XMCLK instead of OSC pin. If SR22[3]=1 & SR24[7]=0, then MCLK comes directly from XMCLK pin and the MCLK and VCLK Synthesizers are powered-down !!

- GRDY signal is similar to OVRW.

- VRDY is similar to EVIDEO if EVIDEO is dynamically switched as a valid data signal.

- EGENn is not needed if we configure Nordic-1M in the right configuration with SR22[3] (XCLKPU) and SR24[7] (VAFCPU).

- As VAFC maximum FCVCLK frequency is 37.5MHz, VAFC supports a mode in which data is sent at 37.5MHz to the DAC and each pixel will be displayed twice if the chip is running at 75MHz pixel clock. This allows only 8bit/pel data to be displayed. To display 16bit/pel data we should use both phases of the FCVCLK and pack the data into one pixel. I think that this is already done in 5428, if not Man-Shek and Fong-Jim are modifying the 5429 RAMDAC to support this mode -> we need to support it too.

- VAFC requires FCDCLK to be switchable under s/w control between 1x and 1/2x the pixel clock. If we took this out of Nordic-1M data base, we should put it back, but the divide by two should affect only FCDCLK going out of the chip.

Check VESA VAFC Proposal 1.0p rev. 0.31 07/15/93 for VAFC timing info.

### Nordic-1M FC Pins Functional Description

Cirrus Confidential  
Business Information

Most of this is from 542X Data Sheet page 3-26:

**VSYNC and HSYNC** TO The standard CRT pins tri-stated when FCESYNCn is L.  
These pins have programmable polarity.

**FCBLANKn** I/O BLANKn in 5428. If FCESYNCn is H, this is an output and it supplies the actual composite BLANKn CRTC signal.  
VAFC requires this to be the composite Display Enable (no borders). If this is the case, we'll need a bit for VAFC that puts DE = HDE & VDE inverted on BLANKn.

If FCESYNCn is L, FCBLANKn is an input and it forces RAMDAC RAM outputs to 0 (black), but it should force them black before they go to the panel.

*It seems that by connecting OVRW output to BLANKn as input we can display FC data in a window - this will work though only if OVRW internally controls the pixel address mux between normal VGA data and the FC data.*

FCP[7:0] I/O P[7:0] in 5428.

If FCEVIDEOn is H, these pins are outputs and represent the pixel address of the RAMDAC.

IF FCEVIDEOn is L, these pins are inputs and represent the pixel address to the RAMDAC.

CR1A[3:2] control the way the FCP[7:0] are muxed with the normal data.

FCDCLK O (the actual pin is I/O) outputs VCLK or VCLK/2 if selected through s/w.  
FCESYNCn I ESYNCn in 5428. Controls HSYNC, VSYNC and FCBLANKn

(H-> outputs, L-> H/VSYNC are tri-stated.

FCBLANKn is tri-stated.).

Nordic does not have EDCLKn input as FCDCLK and FCVCLK are not shared.

OVRW O OVRW in 5428 = Overlay Window. This active Low signal, is generated by the BLANKn VT and HT logic (shared) and is supposed to be used to create an Overlay Window in which data from the Feature Connector is displayed. *I don't know why we output this signal. It should be controlling the MUX between the normal pixel address and the FC originated pixel address.*

## 4.6 On WavePort Architecture and Audio Driver

Starting from Dave Keene's WavePort Specification, Rakesh, Sasha and Vlad came-up with some ideas which could greatly simplify the design work for WavePort, reduction the complexity and the number of gates of the WavePort.

We'll start with the small issues and move towards more important issues.

Cirrus Confidential  
Business Information

### 4.6.1 AUXS1 and AUXS2 Pin

A. Dave proposed to share this pin with PDN (Power Down) WavePort Pin and configure it as AUXS2 when using 4231S.

We noticed that 4231S does have a PDN pin which we'd like to use to save power. We'll put AUXS2 on another pin.

B. Dave proposed to have a fully programmable location for AUXS1 and AUXS2 CPU I/O map with a default at 530H and 388H. This is costly (4 registers and fast comparators) and very difficult to design at required speed: will slow down address range decode for I/O a lot affecting command to command parameters.

We suggest to have a fix address for these ports: 530H and 388H.

Two register bits (one per address) can disable the chip from answering to these I/O

addresses.

If we are not sure where to place these ports, we can leave it as a metal option for future modification or have one more alternative for each, but the address should be fix for fast decode.

GR58:GR5B are no longer needed if this option is accepted. We'll need two bits to disable 530H and 388H address decode and eventually two other bits to select other two alternate I/O addresses. We should always decode 16 addresses: 530:53F and 388:397 (not 4 or 16).

#### 4.6.2 WavePort R/W Buffer Location and Size

To simplify the h/w and reduce verification work-load , WavePort R/W Buffer Size should be fix: 32KB for each. enough for at least 180msec of operation -> 90msec for half buffer. Every 90msec the CPU will have to fill and/or empty half Audio Buffer (write or read respectively).

It is also possible to place the WavePort memory buffer in a fix memory location, common for both desktop and portable architectures. We could place it in Memory in the upper part (in high address area), just before the h/w cursor. If the h/w cursor takes the upper 16KB of the memory, we could use the next 64KB for the WavePort buffer.

Going down in memory, in Nordic we'd place the h/w icon in the next 16KB (only 4KB needed now... but leave some room for expansion) and the Half Frame Buffer for mono-chrome and color panels in the next 32KB and 96KB respectively.

Total:

96KB for CRT/TFT/SS STN panels,  
128KB for monochrome panels and  
192KB for dual scan color STN panels.

out of 1MB or 2MB memory available.

When the memory is expanded, all these fix components should move automatically in the upper side (towards the end of memory).

This places the WavePort buffer at:

- for 1MB of memory by 32 (256Kx32 -> 00000:3FFFF) 3B000:3EFFF
- for 2MB of memory by 32 (512Kx32 -> 00000:7FFFF) 7B000:7EFFF

If we adopt this solution, GR43 is not needed.

Cirrus Confidential  
Business Information

#### 4.6.3 On Host Access to WavePort Buffer

In order to ensure independence between the Graphics s/w Driver and the Audio Driver, taking into account AVGA limitation of no CPU accesses during BLT operation. Dave proposed a separate path for WavePort Host Accesses. This involves a separate 4 stage by 32bit write and read buffer and separate arbitration for the Audio cycles. The buffer is shared by WavePort read and write operations and an I/O to an extension register bit is needed in order to switch from a read operation to a write operation or vice-versa. Dave also proposed that the host address be dependent on GR6 CPU address map bits such that the video and audio address maps don't overlap. Please note that this approach prevents debug with a Hercules card when in graphics.

In the following an alternate scheme is proposed:

- There is one register bit that enables WavePort memory write accesses and one register bit that enables WavePort memory read accesses. When one of these bits is asserted, the chip expects only host accesses for the WavePort: the host address will be automatically translated to a memory address inside the WavePort buffer. The access will be fully linear, 32bit only, **graphics mode independent** (like in extended 8bit/pel). The Graphics block will be forced to this mode and all planes will be automatically enabled. On the Host side, the WavePort buffer will be placed always at A000:0000 - A000:FFFF -> 64KB with 32KB for read buffer (the upper side) and 32KB for write buffer (the lower side of this 64KB segment).
- The CPU Data Path is the same as for any other CPU cycle: no special FIFO, no special arbitration are required. The Audio Driver and The Graphics Driver communicate through interrupts: There is an interrupt for BLT completed (Dave's idea when presented with this proposal) and an interrupt for Audio Buffer Full (or Audio Transfer Completed). When the BLT is completed, if Audio is enabled on the chip, the BLT Completed interrupt allows the Audio Driver to check if there is any need to service the Audio and vice-versa. If possible, the Graphics driver should restrict the extent of the BLT operations to less than 160msec or so (leaving at least 20msec to start filling the WavePort buffer).
- There is no on chip CPU WavePort address generation. The CPU address in the range A0000:AFFFF (incremented by 4 every cycle for DW accesses) is translated to physical memory address 3B000:3EFFF. If host side WavePort pointers are used, the host address is latched and translated for comparison with the Codec pointers generated on chip.

Adopting this scheme would greatly simplify the extent of the design and verification work for WavePort: 8 weeks at least will be saved.

Cirrus Confidential  
Business Information

#### 4.6.4 On the Audio Driver

Dave proposed that the Graphics Controller has h/w to compare the WavePort pointers and generate interrupts. The Codec pointers are I/O readable by the host as well as several buffer status bits (Audio-IN buffer Full, Audio-In buffer half-full, Audio-Out buffer half-empty, Audio-Out buffer empty,...).

Nordic-1M will support Dave's proposed interrupt driven interface.  
In this case the only important difference for the driver will be that it will have to generate the buffers address and not rely on the h/w to do this (Dave suggests that CPU will write and read always the same address A000:0 or B000:0 and the actual address on the host side is generated on the chip - we suggest to change this and let CPU generate the address).

Because CPU has to wait until the a BLT operation is complete and the BLT has to wait for Audio buffer to be full or the transfer completed, two more interrupts are needed: BLT operation completed and Audio transfer completed. This way the Audio Driver and the Video driver can communicate with each other.

Cirrus Logic, Inc. Confidential Information

The Read and Write CPU side pointers will be generated by latching the last read and write WavePort CPU address (lower 16bits only) after translation to physical memory address. Comparators on the host and codec pointers will generate Buffer Full and Buffer Empty signals.

Jeff Ort drew our attention to the fact that the driver transfers a certain size block and needs an interrupt anytime half of what was placed in the Audio buffer was read by the Codec (the play-back buffer is half empty). To make things simple for the h/w, we propose to give Jeff an interrupt when the CODEC side playback buffer read pointer reached a pre-programmed value, value the driver programs everytime it transfers a block of a certain size in the playback buffer. For instance, if the driver put 2KB of data in the playback buffer starting from physical address 3B000 (host address A000:0) and wants an interrupt when the first 1KB was read by the CODEC, it should program 3B0FF in the playback interrupt register, as  $1\text{KB} = 256 \text{ 32bit words}$ . The register will have 16bits and the driver will program BOFF to get an interrupt when the CODEC reads 3B0FF or 7B0FF playback buffer address.

Similarly, on the record side, there will be a programmable interrupt on the CODEC side to be used to tell the driver when the Record buffer is half full.

So we'll need two 16bit indexed registers for these programmable interrupts. For each WavePort interrupt we also need a status bit to say that the interrupt happened, an enable bit to enable the particular interrupt. As Dave proposed, GR4D is the Interrupt Status register but bits [0] and [2] will be the programmable interrupts status bits. The interrupts and the status bits will be cleared after this register is read (automatic clear in h/w).

We could use registers GR58:SB as high and low byte for the programmable interrupt on Record and Play-back buffers respectively.

The write-buffer (or Audio-Out = the one in which the CPU writes) is empty one WavePort write cycle to memory after

$$\text{WRBUF-Write-Pointer} = \text{WRBUF-Read-Pointer} + 1$$

(this condition will activate set an empty flag).

The write-buffer is full one WavePort write cycle to memory after

$$\text{WRBUF-Read-Pointer} = \text{WRBUF-Write-Pointer} + 1$$

The same equations apply to the WavePort read-buffer, only this time the read-pointer is on the host side and the write-pointer on the Codec side.

*Shouldn't be an Audio-Out buffer full interrupt and a status bit for it?*

Cirrus Confidential  
Business Information

Threshold detect mechanism will require to increment host pointers, but the CPU is supposed to read this pointer and generate the proper address when going above the threshold. The idea of the threshold detector is that by incrementing the Audio-In read pointer everytime the write pointer is incremented if the Audio data is under the threshold value, the delta between the pointer remains the same and the buffer does not fill in with sub-threshold value. This was true if the half-full detection had been generated based on the delta between pointers. After talking to Dave, there are some clarifications to be made on the threshold detect mechanism for record:

**Cirrus Logic, Inc. Confidential Information**

For one record session, this is a one time event mechanism: if the threshold was passed once after being enabled, its effect is lost - even if the sound level goes below the threshold the record buffer read pointer works normally. The threshold will help only in the initial stage before the first actual voice pattern is detected, but it does not have any effect after the initial triggering event - once the sound level passed once the threshold.

With this driver approach, GR43 and GR58:5B will not be needed.  
Five registers are saved. Twenty One register are still needed (plus two reserved = 23).

**Another possible approach for the driver uses extensively the Vertical Interrupt:**  
In this case every Vertical Interrupt, the Audio Driver reads the Codec side pointers, compares them with the Host side pointers, the driver generates based on the CPU address it last wrote to or read from and makes its own decisions. The driver will also check the BLT completed status bit.

In other words, every 18msec (@60Hz), on the Vertical Interrupt the Audio driver can process data from the Codec pointers, calculate based on the last address if the WavePort buffer is full or empty and decide how many more WavePort accesses to execute. As at least 180msec worth of data is in a full Waveport Buffer, the driver has 6 opportunities to find out that the buffer is empty and start filling it before half WavePort buffer is empty. On chip h/w is still needed to stop sending data to the Codec after sending all data and to read all data from the WavePort read memory buffer on the host side. Because the CPU decides when the buffers are full, half full or empty there is no need for registers for the pointers on the CPU side, but the CPU address will still be latched to generate the host side pointers.

The "BLT operation completed" and the "Audio transfer completed" interrupts are needed anyway because we share the data-path for BLT and CPU cycles.

By adopting this mechanism in the driver, no special h/w is needed to preserve pointers on the Host side, to compare the Host side pointers (read and write) with the Codec pointers and to generate interrupts and status bits. The only interrupts needed are Standard VGA Vertical Interrupt as a time base, BLT completed Interrupt and Audio Completed interrupt.

We can still implement the threshold detect.

GR44,GR45, GR48 and GR49 won't be needed.

Nine registers are saved. Seventeen register are still needed (19 with two reserved registers).

**Cirrus Confidential  
Business Information**

**Conclusion**

The above proposal, if OK for the WavePort driver, would reduce significantly the amount of design and verification work on the WavePort. This document was written in order to get feed-back and reach an agreement ASAP. Our goal is to have a unique s/w model for the WavePort, but we'd like to cut the amount of work if possible.

Nine registers are saved. Seventeen register are still needed (19 with two reserved registers).

### Conclusion

The above proposal, if OK for the WavePort driver, would reduce significantly the amount of design and verification work on the WavePort. This document was written in order to get feed-back and reach an agreement ASAP. Our goal is to have a unique s/w model for the WavePort, but we'd like to cut the amount of work if possible.

## 4.7 Four Bit per Pel Packed Format

To fully support Windows Chicago, Nordic-1M should support 4bit/pel packed format. CPU will be able to write only 8bits or more at a time. To modify only 4bits the CPU will do read modify write and mask four bits (bring them from CPU latches).

The following picture shows the actual format:

| Memory Data            |          |          |          |          |          |          |          |     |     |     |     |     |     |     |     |
|------------------------|----------|----------|----------|----------|----------|----------|----------|-----|-----|-----|-----|-----|-----|-----|-----|
| 7                      | 4        | 3        | 0        | 15       | 12       | 11       | 8        | 23  | 20  | 19  | 16  | 31  | 28  | 27  | 24  |
| P0                     | P1       | P2       | P3       | P4       | P5       | P6       | P7       |     |     |     |     |     |     |     |     |
| msb                    | lsb      | msb      | lsb      | msb      | lsb      | msb      | lsb      | msb | lsb | msb | lsb | msb | lsb | msb | lsb |
| Pixel Left Pixel Right |          |          |          |          |          |          |          |     |     |     |     |     |     |     |     |
| 1-st pel               | 2-nd pel | 3-rd pel | 4-th pel | 5-th pel | 6-th pel | 7-th pel | 8-th pel |     |     |     |     |     |     |     |     |

In order to get Nordic-1M to support this mode, we need to place the VGA Video Data Path in 8bit per pixel mode with pixel doubling (mode 13) but disable the mechanism that concatenates adjacent 4bits to make one 8bit pixel displayed twice (at a divided by two RAMDAC VCLK) and disable as well dividing by two the RAMDAC VCLK.

On the CPU side chain 4 address scrambling should be disabled and data should be shifted right like in extended 256 color modes.

In nordic-reg9.lst we assigned SR26[0] to enable this graphics mode.

Cirrus Confidential  
Business Information

## 4.8 Robin's Ideas on High Resolution Panels for Nordic-1M

CL 146393

Nordic's objective is to be able to center and fill the screen on 800x600 panels and to center an 800x600 picture on 1024x768 panels. The main focus is 800x600 panel support TFT and dual scan STN.

In TEXT there will be three options:

- horizontal and vertical centering with 9x16 fonts (disable 640x480 force to 8dots font)

#### 4.7 Four Bit per Pel Packed Format

To fully support Windows Chicago, Nordic-1M should support 4bit/pel packed format. CPU will be able to write only 8bits or more at a time. To modify only 4bits the CPU will do read modify write and mask four bits (bring them from CPU latches).

The following picture shows the actual format:



In order to get Nordic-1M to support this mode, we need to place the VGA Video Data Path in 8bit per pixel mode with pixel doubling (mode 13) but disable the mechanism that concatenates adjacent 4bits to make one 8bit pixel displayed twice (at a divided by two RAMDAC VCLK) and disable as well dividing by two the RAMDAC VCLK.  
In nordic-reg9.lst we assigned SR26[0] to enable this graphics mode.

#### 4.8 Robin's Ideas on High Resolution Panels for Nordic-1M

Nordic's objective is to be able to center and fill the screen on 800x600 panels and to center an 800x600 picture on 1024x768 panels. The main focus is 800x600 panel support TFT and dual scan STN.

In TEXT there will be three options:

- horizontal and vertical centering with 9x16 fonts (disable 640x480 force to 8dots font)
- auto-expand the font to fill the screen
- special font to fill the screen

In Graphics there will be tree options:

- horizontal and vertical centering
- use a driver to run at maximum resolution
- automatic expand to 800x600 (only if s/w verification shows it being OK).

In all cases horizontal and vertical options will be decoupled (different enable bits).

Here's a list of what needs to be done:

a. Expand horizontal and vertical centering capability from 640x480 to 1024x768.

b. Shadow all H/V CRTC registers except HDE and VDE.

Cirrus Confidential  
Business Information

The vertical registers are shadowed now, but the horizontal registers are not.  
We need to shadow CR0, 2, 3, 4 and 5. These registers will be written by the BIOS at POST.

- c. Support 10dot character-clock and CRT-FIFO-Read / Shift/Load (Video-Serializer Load). Now only 8dot and 9dot character-clocks are supported. For smooth-scrolling the pel-pan has to be expanded to 10 positions (0:9).
- d. TEXT auto-expand will be as follows:
  - horizontal: replicate the last pixel once for 9 dots wide fonts and twice for 8 dots wide fonts.
  - vertical: replicate all odd scan-lines

TABLE 3. Font Expansion for Different Panel Sizes

| Font-Size/Panel-Size       | 480  | 600   | 768            |
|----------------------------|------|-------|----------------|
| 8x14                       | 8x19 | 10x21 | 10x21 + center |
| 8x8 with scan-in. doubling | 8x19 | 10x24 | 10x24 + center |
| 9x16                       | 8x19 | 10x24 | 10x24 + center |

Please note that in text vertical expansion is done on the scan-line counter as well as the vertical display line counter, but it does not affect the vertical non-display line counter.

- e. Graphics modes expansion (to be implemented only after s/w verification)  
Graphics expansion is less important as it is assumed that important applications will run at maximum panel resolution with a driver.  
We'll need to supply drivers for many applications with high res. panels !!

Vertical expansion:

- 350lines -> replicate all odd scan-lines
- 400lines -> replicate all odd scan-lines
- 480 lines -> replicate every 4-th line

Horizontal:

- center
- duplicate every 4-th pixel
- duplicate every 4-th pixel with diagonal shift

(scan-line 0 -> 1st pel, scan-line 1 -> 2nd pel, scan-line 2 -> 3rd pel, scan-line 3 -> 4th pel).

## 5.0 Nordic-1M Pinout Specification 208 pin package:

Cirrus Confidential  
Business Information

CL 146395

System Interface (reference is VESA VL bus): 73

Cirrus Logic, Inc. Confidential Information

(on BVDD)

DAT31:0

HIMEM (normally used as ADR24, but it can be used as ADR31 and leave 2GB of upper address space reserved for MPEG/JPEG boards)

ADR23:2

BE3n.BE2n.BE1n.BE0n

LADSn.LDEVn.RDYn

M/IOn, W/Rn

RESET, LCLK

RDYRTNn.

EBROMn/VADRn/AUXS2 (Enable BIOS ROM Buffers on all busses or Valid Address - CPU

Address in Nordic valid address range I/O or memory or Auxiliary Select 2 to be used to select the Audio Synthesizer or some other audio chip)

INTR, CLK32K/OVRW, OSC/XVCLK (14.318MHz)

SUSPIn/BLIn/FCBLANKn, SBYIn/ACTIn/FCEVIDEOIn

(32KHz clock input / FC Overlay Window Output controlled by VAFCPU.

Suspend Input/ Back-Light Input/VAFC BLANKn I/O signal controlled by VAFCPU - pin configuration -and FCESYNCn - FCBLANKn direction and HSYNC/VSYNC HI-Z or not;

Stand-by Input/Activity Input/VAFC External Video Control Input - controls the direction of FCP[7:0]. Pin configuration controlled by VAFCPU).

Configurations: - VL/PCI/ISA bus, support/not BIOS, 8/16bit BIOS.

- Need a register bit to select SUSPEND Input or Back-Light Input. Default is SUSPEND Input.
- Need a register bit to select Stand-By Input or Activity Input. Default is Stand-By Input.
- SUSPIn, BLIn, SBYIn, ACTIn are level triggered, active L inputs.  
In Nordic there is no Suspend pin polarity bit as in T1 (SR8[4]).

**Note:** a.In PCI bus, Alpine used ADR17:2 as BIOSA15:0. We assume that all portable systems will use a motherboard video BIOS and do not support an adapter BIOS in PCI. We do support an adapter BIOS in VESA VL bus and ISA to facilitate demo board design.

b. EBROMn is active on all bus types: in ISA is generated on Address Decode and MEMRn, while in VL and PCI is unlatched address decode. In PCI bus the BIOS should be relocatable, an option we do not support. That is why we say that we do not support BIOS in PCI. We do support IOCHRDYn and RDYn/TRDYn for BIOS accesses too. All this logic should already be in 5428 (ISA and VL) and Alpine (PCI).

c. The 5428 Feature Connector pins are available in all buses. A register bit enables them early in the logic to save power when not in use.

Cirrus Confidential  
Business Information

CL 146396

Cirrus Logic, Inc. Confidential Information

**DRAM Interface (for assymetric, dual WEn 256Kx16 DRAM-s); 50**  
 (on DVDD)

MA9:0  
 MD31:0  
 RAS0n.RAS1n.CASn/WEn, OEn  
 WE0n/CAS0n,WE1n/CAS1n,WE2n/CAS2n,WE3n/CAS3n

Configurations: symmetric/assymmetric DRAM, dual WEn/CASn

- Note: a) For dual CASn DRAMs, the WE0n:WE3n pins become CAS0n:CAS3n, while CASn becomes WEn.  
 b) Two RAS-es are used for two banks.  
 c) OEn is not actually needed as we use early write.

**Clock Synthesizers: 6**

(MAVDD, MAVSS feed mclk clock synthesizer, VAVDD, VAVSS feed dclk clock synthesizer)

MAVSS, VAVSS, MAVDD, VAVDD,  
 MFILTER, VFILTER  
 (Can we design a clock synthesizer without an external filter?)

**CRT Interface and RAMDAC related pins; 10**

(DAVDD, DAVSS feed all RAMDAC custom layout)

R,G,B (analog)  
 IRef, DCVDD1, DCVDD2, DCVSS1, DCVSS2  
 HSYNC , VSYNC TO (these two pins are on BVDD )

**FLAT PANEL and Power Management Interface (on PVDD); 31**

R7/FCP[3], R6/FCP[2], R5:0, G7/SUSPSTn/FCP[1]  
 G6/SBYSTn/FCP[0], G5:0, B7/MOD, B6/FCVCLK, B5:0  
 (use slow edge pads and stagger them modulo 4)  
 FPVCLK, LLCLK, LFS, FPDE, (use slow edge output pads)  
 FPVCC, FPBL, FPVEE

Cirrus Confidential  
 Business Information

Notes:

CL 146397

- b. R7:6, G7:6, B7:6 (24 bit TFT panel extra video data out pins)
- c. We need also bits for SUSPST and STANDBYST, PANEL-ON/OFF, PANEL-IN-POWER-UP-or-DOWN.
- d. We assume that the 24bit TFT panels do not need external MOD.

- e. No NPD pin.
- f. FCP[3:0] pins are I/O-s whose direction is controlled by FCEVIDEOOn in VAFC configuration. FCVCLK is the clock that clocks them in and which should be used to clock them while they are displayed or at least to resynchronize them before being latched on the internal clock. FCVCLK is always an input when in VAFC configuration.
- g. Nordic-1M facilitates NTSC output by providing RGB 6:6:6 just before DAC on the R5:0, G5:0, B5:0 when in a special mode. It also provides odd/even frame signal and true Display Enable in sync with the RGB. Nordic-1M will run in terlaced mode when in NTSC Out mode. All the needed signals will be comming out on the Flat Panel Pins in the NTSC Out mode.

Audio Port (on ADVDD): 6

SDO (SErial Data Output to CODEC pin SDIN)

SDI (Serial Data input from Codec pin SDOUT)

FSYNC (Frame Sync Output)

SDCLK (Serial Data Clock I/O )

D/Cn/AUXS1 (Data/Control Select Output or CS4231S Chip Select for the ISA bus)

PDN (Power Down Output)

Note: These pins can be used as extensions for 24 bit TFT panels, in which case the chip does not support the audio port. Note also that CS4215 has Resetn pin.

Cirrus Confidential  
Business Information

Miscellaneous Pins: 10

Following pins on MVDD:

TRWn I (Test Latch Load Enable, active L - for pinscan & test mode)

SW2 I ( Switch #2 or reserved for SDRAM support in the future)

SW1/MCLK/XMCLK I/O with PD controlled by XReset

(Switch #1 or mclk driver buffered output for testing and debug or external mclk for testing; a special register bit disables this output in normal operation for power savings.)

Default: Input on which either SW2 or XMCLK comes in.

Only if the special register bit

is set, this input becomes output and outputs MCLK from the clock synthesizer for testing.

The special register bit defaults 0 = the pin is configured as Input. Please note that a h/w configuration PU/PD controls if the actual internal mclk comes from an internal or external source, but this PU/PD does not control if

(SW2/MCLK/XMCLK is an input or an output.)

RES4CKE O NC Pin Reserved for Future Nordic chips

**Following Pins on BVDD:**

SW0/VCLK/FCDCLK I/O (Switch #0 Input or vclk driver buffered output for testing and debug, or VAFC Dot-Clock Out ; Default for this pin is Input on which SW#0 is applied. VCLK and FCDCLK is the same signal, the name is different to ease reference to VAFC spec )

**Following Pins on PVDD:**

FCP[7:4] I/O Feature Connector Data Pins bits 7 to 4. The other Feature Connector pins are shared with some panel or host bus pins.

FCESYNCn/RES4SDCLK I 5428 Feature Connector ESYNCn pin - controls the direction of FCBLANKn and its effect and tri-states HSYNC and VSYNC.

DRAFT = TX-150006

**System/Bus Interface Signal Mapping**

(See 54xx Reference Manual for Feature Connector Pins Description: FCyyyy)

TABLE 4. VESA-VL &lt;&gt; PCI bus &lt;&gt; ISA bus Pin Mapping

| VESA-VL  | Intel-PCI | ISA         |
|----------|-----------|-------------|
| HIMEM    | --        | --          |
| ADR23:16 | --        | LA23:16     |
| ADR15:9  | --        | SA15:9      |
| ADR8     | PAR       | SA8         |
| ADR7     | STOPn     | SA7         |
| ADR6:2   | --        | SA6:2       |
| BE3n     | C/BEn3    | SA1         |
| BE2n     | C/BEn2    | SA0         |
| BE1n     | C/BEn1    | SBHEN       |
| BE0n     | C/BEn0    | RFRSHn      |
| DAT31:22 | AD31:22   | --          |
| DAT21:19 | AD21:19   | --          |
| DAT18    | AD18      | MWRn        |
| DAT17    | AD17      | IOCS16n     |
| DAT16    | AD16      | IRQ         |
| DAT15:0  | AD15:0    | SD15:0      |
| RESET    | RESET     | RESETDRV ?? |
| LADSn    | FRAMEn    | BALE        |
| LDEVn    | DEVSELn   | MCS16n      |
| RDYRTNn  | IRDYn     | AEN         |

Cirrus Confidential  
Business Information

CL 146399

**TABLE 4. VESA-VL <> PCI bus <> ISA bus Pin Mapping**

| VESA-VL      | Intel-PCI | ISA         |
|--------------|-----------|-------------|
| W/Rn         | IDSELn    | IORn        |
| M/IOn        | --        | MRDn        |
| LCLK         | CLK       | IOWn        |
| RDYn         | TRDYn     | IOCHRDY     |
| EBROMn/VADRn | VADRn     | EROMn/VADRn |
| INTR         | INTR      | ZEROn       |

- Notes:
1. SW2, SW1/MCLK/XMCLK and SW0/VCLK pins are normally used by the BIOS as panel type switches readable on SR24[2:0].
  2. XMCLK and XVCLK (on OSC/XVCLK) are needed for manufacturing test of the chip. When they are used, SR24[1:0] will wiggle at clock rate and they should be masked on the tester.
  3. MCLK and VCLK are needed for manufacturing test of the clock synthesizer and for chip debug.

#### Digital Mixed Voltage Power Pins: 22

BVDD1, BVDD2, FPVDD1, FPVDD2, MVDD1, MVDD2, ADVDD,  
 CVDD1:4, (BVDD goes now to HSYNC and VSYNC)  
 VSS1:11

Total Pins Used: 208 (with no pin left).

Cirrus Confidential  
 Business Information

#### Pinout Modifications in rev. 3.8 relative to rev. 3.7 09/11/93

1. Took-out Whisper Support Pins: WWRn, WRdn, WAD[3:0], FPCn. CL 146400
2. Reduced the number of CPU Address Pins: ADR[24:27] went-away. Use HIMEM to place the chip outside 16MB of memory for linear addressing.
3. Killed CRTVDD and placed CRT Interface on Host Bus VDD.
4. Introduced VAFC pins in a unique pinout configuration in both VESA VL and PCI. Added VAFCPU a pull-up to enable VAFC (VESA Advanced Feature Connector). ADR[27:24] VAFC pins, and R[7:4], G[7:6], EROMn/VADRn, SUSPI/BLI, SBY1/ACT1 get a configuration for VAFC -> total 14 pins.  
 SW0/VCLK will be used as VAFC VCLK, losing SW0 pin as panel type when VAFCPU is used.  
 In PCI bus, no ADR pin will be shared with VAFC.  
 ASW0PU (Alternate Switch 0) will be added on MD pins to replace SW0 pin when VAFC is enabled by VAFCPU. ASW0PU will read-back in the same register bit as SW0.

20000714 - 200100

## Cirrus Logic, Inc. Confidential Information

so the BIOS will not feel any modification in the reporting scheme. The chip will draw more power in suspend with VAFC.

5. Moved SW2, SW1/MCLK/XMCLK the two reserved pins (one obtained by killing CRTVDD) and TRWn on MVDD to prepare for SDRAM pin compatible option in the next Nordic that supports SDRAMs. Marked them as "reserved for SDRAM pin name". It looks that TRWn will not be needed, but it was moved on MVDD so that in case it is needed, it is available (in this case we'll need an extra switch for SDRAM support or at least to disable TRWn test mode effect).

6. Rearranged VAFC pins as pins R4 and R5 were used by VAFC - an error.

## Configuring Nordic-1M

If Terminator used specially assigned pins to configure the chip, Nordic-1M will use some of the MD31:0 pins sampled on the Reset trailing edge, similar to Mustang. The pad cells will have an active pull-down controlled by an extended Reset signal. The pull-down resistance will be about 75KOhm. An external pull-up less than 60KOhm is needed only if the option is used. In Suspend, the MD pads are inputs and the DRAM OEn is H so no DC current is drawn by the configuration h/w. An external resistor is needed only if the configuration pin has to be H at Reset. All h/w configuration latches are read accessible via I/O. The h/w configuration is latched on Reset trailing edge. (these latches were r/w, with s/w PU read, having only read is enough).

We'll define the configuration pins to minimize the number of external resistors:

### CPU Bus Configuration:

|                                |                                                                            |
|--------------------------------|----------------------------------------------------------------------------|
| On MD18:16 & -> no external PU | = 32bits VESA VL bus at 33MHz or less bus clock                            |
| & MD23                         | -> MD16 PU = 32bits PCI bus with Burst PU called "PCIPU"                   |
|                                | -> MD17 PU = 16bits ISA bus PU called "ISAPU"                              |
|                                | -> MD18PU = 32BIT VESA VL BUS AT 50MHZ BUS CLOCK PU called "FVLPU"         |
|                                | -> MD23 PU = 32bits PCI bus no Burst PU called "PCINBPU"                   |
|                                | This is a reserved configuration in case burst does not work on a PCI bus. |

### Reads-back in SR22:

|                            |
|----------------------------|
| PCIPU on MD16 -> SR22[0]   |
| ISAPU on MD17 -> SR22[1]   |
| FVLPU on MD18 -> SR22[2]   |
| PCINBPU on MD23 -> SR22[7] |

Cirrus Confidential  
Business Information

CL 146401

**Clock Configuration:**

- | On MD19 (reads back on SR22[3])  
-> no external PU = internal MCLK and VCLK clocks, from the internal clock synthesizer
- | -> MD19 PU = use external clocks from SW1/MCLK/XMCLK and OSC/XVCLK  
PU called "XCLKPU"

This PU is used for manufacturing test.

One reg. bit is needed if internal clock is selected to control outputting mclk on the MCLK/XMCLK pin = 1 if use internal clock then output it on SW1/MCLK/XMCLK pin. -> SR23[0] is this bit.

CONFIDENTIAL INFORMATION

**Memory Configuration: SRF[0]**

No Pins, Use Two Register Bits -> 2CAS/2WE bit=H 2WE, bit=L 2CAS (default =L)  
-> Symetric/Asymetric bit=H Asym., bit=L Sym.  
(default=L)

- | **BIOS Support:** (reads-back on SR22[6] for BIOS8PU)

Nordic-1M supports 16bit or 8bit BIOS and only in ISA bus configurations.  
The BIOS is always supported when in ISA.

On MD22 -> no external PU = 16bit BIOS

-> external PU = 8bit BIOS (no MEMCS16n decode on C000)

This option is mostly for debug in case 16 bit BIOS range decode is not fast enough.  
If the BIOS support is disabled, this configuration is don't care. Called "BIOS8PU".  
Please note that Nordic-1M supports C000 BIOS only in ISA.

In a normal note-book the BIOS is at E000:0, not supported by Nordic; so no external component is needed.

**Sleep Address Selection:**

On MD21: Sleep Address Selection (reads-back on SR22[5]).

-> No external PU = sleep at 3C3[0] - to be used when Nordic is on the Mother-board (most cases)

-> External PU = sleep at 46E8[3] - to be used when Nordic is an adapter (like a PCMCIA card and/or an adapter to turn desktop into an environment friendly PC) Called: S46PU

Cirrus Confidential  
Business Information

## Cirrus Logic, Inc. Confidential Information

Note that Nordic-1M comes-up awake, though this has to be cleared with the BIOS group.

**Feature Connector Configuration:** (reads-back on SR24[7])

On MD25:

-> No external PU = no Feature Connector Support: outputs used only for FC are forced L. I/O are forced inputs, I/O and inputs are forced on the chip so that they do not take power if not connected externally.

-> External PU = All pins needed for FC including OVRW are active.  
Called: VAFCPU

On MD26: Alternate SW0 Selection (Reads-back on SR24[0] when SR24[7] is 1)  
When SR24[7] is 1, SW0 pin is forced to output DCLK and this external PU latched on Reset trailing edge plays as SW0. It reads back at the same bit as SW0 does.

-> No external PU = SW0 reads back 0 in SR24[0]  
-> External Pu: SW0 reads back 1 in SR24[0].

| Total: 10 H/W PU configuration options.

In normal operation with FC enabled up to three external PU-s may be needed (bus type if not VL and FC).

In normal operation with FC disabled up to one external PU-s may be needed (bus type if not VL and FC)

Summary of PU/PD Configuration Pins and Register Bits where they can be read-back:

#### SR22[7:0] H/W Configuration Read Register #1

Read only register, written on reset training edge by activating PU/PD on MDi pins. The PD-s are inside the pads active only during XReset (extended reset).

| [7] 32bits PCI bus no Burst h/w PU configuration on MD23. It is called "PCINBPU"  
(read only bit).

This is a reserved configuration in case burst does not work on a PCI bus.

| [6] Select 8 bit BIOS support (if 1). Otherwise 16 bit BIOS support if the BIOS support is at all enabled. PU on MD22.

Cirrus Confidential  
Business Information

[5] Reserved for Sleep Address Select: reads back S46PU (MD21).

1 = I/O address 46E8[3] as sleep address (needs external PU).

0 = I/O address 03C3[0] as sleep address (no external PU is needed).

CL 146403

| [4] Reserved

[3] Select external clocks: MCLK and VCLK on SW1/MCLK/XMCLK and OSC/XVCLK. (default: internal clock synthesizer, SW1 and OSC).

| PU on XCLKPU on MD19.

- 0 = internal clocks with the pins used as inputs for panel type switch #1 and OSC.  
If SR23[4] and SR23[0] are 1, SW0/VCLK and SW1/MCLK/XMCLK,  
respectively become VCLK and MCLK outputs respectively, for test purposes  
(only if SR22[3]=0 MCLK can be seen, but VCLK can be seen even if SR22[3]=1  
as long as SR23[4]=1)
- 1= SW1/MCLK/XMCLK and OSC/XVCLK become XMCLK and XVCLK inputs  
generating directly chip MCLK and VCLK without clock synthesizer. The clock  
synthesizers are powered down if SR22[3]=1.

[2] Select VESA VL Bus at 50MHz

- | 1 = VESA VL bus at 50MHz selected (needs external PU on MD18)  
0 = VESA VL bus at 50MHz not selected

[1] Select ISA Bus with PU on MD17.

- 1 = ISA bus selected (PU on MD17)  
0 = ISA bus not selected (no PU on MD17)

[0] Select 32bit PCI Bus with PU on MD16.

- 1 = 32bit PCI bus selected (PU on MD16)  
0 = 32 bit PCI bus not selected (no PU on MD16)

If [1:0] = 00 (i.e. no external PU on MD17:MD16) 32bit VESA VL bus is selected.  
No more than one PU on MD17:MD16 should be used.

Note: In AVGA3, CF14 is "Enable Local BUs Address Latching Interface". Alpine does not have this configuration bit. We need to do what was done in Alpine to get rid of this Configuration Pull-up/Pull-Down option. CAN we? WAS this done, Dwarka?

### SR24 Panel Type Switches Register

[7] VAFCPU (VESA Advanced Feature Connector External Pull-up) Read-back.  
If external pull-up (the bit read-back 1) then all VAFC pins are configured for Video Port.  
Otherwise they have other functions or are disabled if no other function. (Disabled= the  
inputs are forced = the TTL and CMOST threshold controls are off & the outputs are tri-  
stated. It actually reads back what is latched on Reset on VAFCPU. VAFCPU is on  
MD25.

[2:0] SW2:0 pins read back (read only bits) Please note that bit [0] reads back SW0 if  
VAFCPU (SR25[2]) is 0 and ASW0PU if VAFCPU is 1. ASW0PU is on MD26.

#### Configuration Register Bits needed:

Cirrus Confidential  
Business Information

Symmetric/Asymmetric DRAM -> SR8[7] in T1, CF13 in AVGA3

=&gt; SRF[1] 0 = Symetric DRAM Default: 0

1 = Assymetric DRAM

This bit is read only in AVGA3 (reads back CF9), but it is writable in T1. It controls MCLK frequency as an alternate to SR1F. We will use only SR1F to program MCLK frequency in Nordic. The default MCLK frequency will be 39.374MHz, corresponding to SR1F[5:0] = 18H=22D. This frequency fully meets the spec for -80 256Kx16 DRAM-s.

Two CAS or two WE DRAM -> pin 72 in T1, CF12 in AVGA3

=&gt; SRF[0] 0 = 2 WE DRAM (Default:0)

1 = 2 CAS DRAM

16 or 32bit wide Video Memory (One or Two 256Kx16 DRAM-s or SDRAM-s)

-&gt; not in T1, SRF[4:3] in AVGA3 (01=16bit, 10=32bit)

=> SRF[7,4:3] will be used in Nordic with the same encoding as in AVGA3.  
(11 is reserved for 64bit wide). Default: 10 (32bit). See Table next page.

Please note that we have room to add other types of DRAM-s (SDRAM-s for instance).

In AVGA3 SR8[0] is "CS OUT to EEPROM" a feature Nordic does not Support.  
Nordic will not change the meaning of AVGA3 bits unless they are read only  
(like the pins or external PU read back).

SR8[2:0] are in T1 the read-back bits for SW2:0 input pins, but AVGA3 uses them for EEROM programming so we moved SW2:0 read back to SR24[2:0].

In T1 SR8[7] is symmetric/assymetric addressing... in Nordic this is SRF[1].

Two or one Bank 32bit wide DRAM

-> not in T1, SRF[7,4:3] in AVGA3 (00=8bit, 01=16bit, 10=32bit, 11=64bit, SRF[7] controls if 2MB of Video memory are available with 4x512Kx8 -0- or with 4 256Kx16 DRAM-s, twoi banks -1-). It seems that in AVGA3 to support 1MB with two 256Kx16 dram-s and 32bit wide bus, we select 32bit wide and SRF[7]... but I do not exactly know how this configuration is selected.

=> SRF[7,4:3] in Nordic, will select the Video Memory Configuration slightly differently than in AVGA3 and Alpine. See the following table.

Cirrus Confidential  
Business Information

|       | SRF[7] | SRF[4] | SRF[3] | Memory Configuration            | CL 146405 |
|-------|--------|--------|--------|---------------------------------|-----------|
| new   | 0      | 0      | 0      | 32bit, 2MB=4x512Kx8             |           |
|       | 0      | 0      | 1      | 16bit, 512KB=1x256Kx16          |           |
|       | 0      | 1      | 0      | 32bit, 1MB=2x256Kx16 (default)  |           |
|       | 0      | 1      | 1      | Reserved (64bit in Alpine)      |           |
| new ? | 1      | 0      | 0      | 32bit, 2MB=4x256Kx16, Two Banks |           |
|       | 1      | 0      | 1      | Reserved                        |           |

|   |   |   |          |
|---|---|---|----------|
| 1 | 1 | 0 | Reserved |
| 1 | 1 | 1 | Reserved |

DRAM Timing select (short RAS or long RAS)

- > SRF[2] in T1 and AVGA3
- => SRF[2] in Nordic, default 1 = short RAS (3.5 L, 2.5H)

BIOS 48KB or 32KB -> not in T1; CF8 in AVGA3. In T1 SR8[4] is Suspend pin polarity.

- In Nordic Suspend pin is always active L (0 on pin puts the chip in Suspend).
- => SR23[2] in Nordic =0 32KB BIOS (default=0) C0000:C7FFF  
=1 48KB BIOS : C0000:CCFFF

The initial BIOS code should be placed in the first 32KB starting at address C0000.

BIOS ROM ZERO\* wait select in ISA and fast timing in VL bus

- > not in T1; CF1 in AVGA3
- => SR23[1] in Nordic =0 no ZERO wait state for BIOS in ISA and slow, safe BIOS timing in VESA VL and PCI.  
=1 ZERO wait state for BIOS in ISA, 8MHz bus

Output internal VCLK on VCLK/XVCLK pin -> not in T1 or AVGA3

- => SR23[4] in Nordic =0 if SR22[7]=0, then VCLK/XVCLK is an output pin forced L  
=1 if SR22[7]=0, then VCLK/XVCLK is an output pin and it outputs VCLK.

0000000000000000000000000000000000000000000000000000000000000000

Output internal MCLK on MCLK/XMCLK pin -> not in T1 or AVGA3.

- => SR23[0] =0 (default) force L on the pin  
=1 output mclk

Suspend/BLI bit -> not in T1 or AVGA3.

- => SR23[5] in Nordic, 0= Suspend pin in Suspend/BLI pin (default)  
1= BLI pin on Suspend/BLI pin

Cirrus Confidential  
Business Information

SBY/ACTI bit -> not in T1 or AVGA3

- => SR23[6] in Nordic, 0= SBY on SBY/ACTI pin (default)  
1= ACTI on SBY/ACTI pin

CL 146406

Video Port Enable bit active in PCI bus -> not in T1 or AVGA3.

(read only bit, actually reflecting the status of an external configuration PU: FCPU on MD25 latched at RESET or under S/W Control)

- => SR24[7] 0= Video Port Disable at pins to save power: inputs are forced.

outputs are L. I/O-s are inputs forced H in case they are not connected in the system.  
If any shared pins, they are not in Feature Connector configuration.

1= Video Port Enabled at pins.  
If any shared pins, they are now in Feature Connector Configuration.

Live Video Enable bit -> not in T1 or AVGA3.

=> SR24[6] 0= disable (default)  
1= enable

Audio In (from CS4215 to Nordic) Enable bit -> not in T1 or AVGA3.

=> SR24[5] 0= disable (force inputs inactive and outputs L disable AI-FIFO and cycles)  
1= enable

Audio Out (from Nordic to CS4215) Enable bit -> not in T1 or AVGA3

=> SR24[6] 0= disable (as above but AO-FIFO)  
1= enable

Panel Type Switch Read-back -> SR8[2:0] in T1 or SR7[6:4], not in AVGA3

=> SR24[2:0] in Nordic, read only, writable on Reset or under S/W Control (SR24[3])  
When SR24[3] whose default is 0, transits from 1 to 0 SW2:0 pin value is latched into SR24[2:0] which cannot be written by I/O.

Cross Talk Reduction Enable -> not in T1 or AVGA3.

-> SR24[3] =0 disable (default)  
=1 enable - the pinout is configured to support cross talk reduction chip. The I/O registers for the cross talk reduction chip are always decoded, to make things simple. Reserve SRFX for this purpose.

Please note that R9x[1:0] TFT Panel type field of T1 was expanded to support 24bit TFT panels:

00 -> 9bit (333) (as in T1)  
10 -> 12bit (444) (as in T1)

Cirrus Confidential  
Business Information

CL 146407

Cirrus Logic, Inc. Confidential Information

01 -> 18bit (666) [was x1 in T1 covering both 01 and 10 !!]  
11 -> 24bit (888) -> new in Nordic

Notes:

- a. If 24bit TFT panel is selected, all related pins will be configured for it and it has priority over panel pins configuration settings for cross talk reduction enabled.
- b. If 24bit TFT is not selected then MOD is selected on MOD/B7 pin.
- c. If STN Panels Cross Talk Reduction support is selected, and TFT type is not 24bits, then the Cross Talk Reduction support pin configuration is selected.
- d. If 24bit TFT is not selected, then SUSPST is selected on G7/SUSPST and SBYST is selected on G6/SBYST and MOD is selected on MOD/B7.

**Other Register Related Topics**  
(See **nordic-regs-rev#.lst** where # is the latest one)

**BIOS SScratch Registers #5 and #6 (2 extra required) (r/w)**

SR28:SR29[7:0] are scratch registers.

Note that SR9, SRA, SR14 and SR15 are AVGA3 scratch registers which we keep in Nordic. Also there are 13 18 bit scratch registers in the RAMDAC as SR12[1]=1.

**R9x - TFT Panel Data Format**

-----  
[7:5] Reserved

[4:2] Select a 0 to 7 shift-clock delay from the internal character clock counter  
(8 VCLK/Character Clock) to TFT panel HSYNC (LLCLK) signal -> as in T1.

[1:0] TFT Panel Type:

00 -> 9bit (333) (as in T1)

10 -> 12bit (444) (as in T1)

01 -> 18bit (666) [was x1 in T1 covering both 01 and 10 !!]

11 -> 24bit (888) -> new in Nordic

Cirrus Confidential  
Business Information

**Registers that are Moved Relative to T1**

**CL 146408**

**Cirrus Logic, Inc. Confidential Information****CR1B[7,4,3,2] (R1B in schematics):**

- [7] Disable Text Cursor Blink in T1. Do we use this feature in T1?  
Enable Blank End Extensions in AVGA3
- [4] PCLKO (Panel Clock) no divide by two control in T1.  
I am not sure this bit is actually needed in Nordic.
- [3] IRQ Every Frame or Every Other Frame ? Is this bit used in T1?
- [2] Not Used at All in T1.

I think that all these bits are not actually used. Are they needed ? -> Robin.

**CR1C[7:0] & CR1D[7:0]**

Are important LCD and Power Management Registers in T1 and Overlay Registers in Alpine. These registers are not in AVGA3, but because they are used in Alpine we may move them to CR2C[7:0] and CR2D[7:0], which requires one more CRTC Index Register Bit. So:

CR1C -> CR2C & CR1D -> CR2D in Nordic relative to T1.

**SRF[7]**

In T1 is CRT Refresh Disable. This bit gates /FB/RWC[5] in FB sheet 6. In AVGA3 is DRAM Two Bank Configuration select bit.

I don't think that this bit is used in T1 ? -> Robin.

**SR16**

In T1 is used to control the pads for power and threshold. In AVGA3 is not used. In Alpine is CRT FIFO demand threshold and other things ([4:0] are used).

Move SR16 bits of T1 to SR20 to avoid contention with Alpine. Increase SRX Sequencer Register Index to 6 bits.

**SR1A**

In T1 is used as Test register. In AVGA3 and Alpine is Signature Generator Result Hi. Move T1 SR1A bits to SR21 if it is not replaced by a similar register in AVGA3.

**Nordic Revision and Mask Codes**

Nordic Revision: ??

Nordic Mask Code: 00

**Cirrus Confidential  
Business Information**

-----\$\$\$\$-----

**CL 146409**

B2

\*\*\*\*\*  
\* User name: SHAW (11) Queue: UIDESK/UNIX\_UIMXST  
\* File name:  
\* Directory:  
\* Description: Sashas\_v.lp Server: CLFPCD010  
\* December 21, 1998 7:10pm  
\*\*\*\*\*

EXHIBIT

RX-571 C

SSS H H A W W  
S S H H A A W W W  
S H H A A W W W  
SSS HHHHH A A W W W  
S H H A A W W W  
S S H H A A W W W  
SSS H H A A W W

L SSS TTTTT  
L S S T  
L S T ::  
L SSS T ::  
L S T ::  
L S S T ::  
LLLLL SSS T ::

20000421 11031000

Cirrus Confidential  
Business Information

CL 158871

CONFIDENTIAL

LIVE VIDEO SCHEME PROPOSAL  
=====  
by SASHA EGLIT rev. 0 06/17 '93

1. OVERVIEW  
=====

This proposal is related to Real-time Laserdisc-quality live video system for notebook-type of PC.

1.1 GOALS  
=====

The main goal of proposed design is to achieve high-quality live video on LCD based machine while minimizing cost of hardware embedded into LCD controller, which will provide for preserving of low PC cost for users which will not need live video. It is highly desirable to avoid any expensive solution which will be common for all system configurations. We will try to keep additional hardware cost for LCD controller under \$1.00 (\$1.50 worst case).

By the term "High Quality live video" we understand real-time video with 640x480 pixels (square pixel mode) and 30 frames per second (fps). Informally, image quality should be comparable with one provided by LaserDisc medium.

To be able to run under MS Windows, video data stream should be genlockable to VGA image.

Primary output devices for this system will be LCD panels (mostly, color ones; but it should be possible to use mono panels, too); but system should be simul-scan capable (mostly, for marketing reasons).

Also, there are rumors - it will be good if we can capture video clip in real time for editing and creating animated presentations (at least, if system will provide this feature without additional cost!).

We also think, design should be based on existing explicit or implicit standards (like local buses of different kinds, PCMCIA, etc.).

1.2 SCOPE OF THIS MEMO  
=====

This memo covered video subsystem from digital YUV video bus with 4:1:1 or 4:2:2 subsampling to LCD interface. Front end for this system can be any popular digital video decoder chipset (For example, Philips DMSD and DMSD2 chipsets).

Particularly, we will discuss implementation of basic part, which will be implemented on LCD controller chip. We will also do some system bus and video memory bandwidth calculation to get pessimistic estimation of possible system overhead and worst-

Cirrus Confidential  
Business Information

CL 158872

NOTEBOOK TECHNOLOGY

case limitations.

## 2.1 TRADITIONAL WAYS =====

At present, there are lot of known different approaches to get live video into computer display device. The most popular one is overlay-based scheme. In this scheme, VGA controller provides switching of data source for last stage of data path (for instance, DAC data bus) between VGA video controller data and real-time video overlay data. This approach has several advantages for desktop-type PC: it required minor modification of VGA controller (usually, color keying is the only thing which is done on VGA side), easily provide high enough data rate necessary for live video, doesn't consume video buffer bandwidth, doesn't required complicated video compressors/decompressors and even provide some degree of VGA mode independence.

For LCD-based machines this approach has some disadvantages, though. Main problem, from our point of view - this scheme doesn't provide flexibility for PC manufacturer - this guy have to include live video support into every system he makes. This problem arise because overlay scheme introduce some custom (well, it can be informal semi-standard from VESA) video data bus. For desctop it's fine - this bus exists on add-on VGA/Video board only and doesn't introduce additional cost for basic system configuration. We think, this scheme can be a problem for laptop-type PC, because each system should have custom video bus on computer board, even if end-user doesn't have any intention to use live-video option. Overlay-type scheme can easilly introduce substantional extra cost just on board-level.

Also, desktop VGAs have Feature Connector (in most cases, at least). Thus, overlay video bus usually will not introduce additional requirements for IO pads. In laptop world, this scheme will cost us at least 10 pins (for 8 bit bus), which will also increase overall system power consumption.

Panel interface-based overlay scheme looks much better in this sense, but has serious problem - impossible to have simulscan (marketing don't like this).

Page 3

Other problem with overlay - lack of modularity on system level; this means, if you bought notebook without live video (but with LCD controller which provides overlay capability) and you would like to add this nice feature later, how you can do this? There is no "slots" in most laptops (how's about sub-notebooks?). Overlay scheme can lead to some custom video connector for add-on box or it can be PCMCIA port with custom interface addition - all this solutions doesn't looks too attractive for PC manufacturer (additional cost, size, weight, etc). Any customizing of PCMCIA standard port will limit flexibility of laptop designer and will looks like attempt to sell a "bundle" - LCD controller and custom PCMCIA host adapter. Also, overlay scheme will require genlocking of live video part to LCD scanning, which also can cost something.

Cirrus Confidential  
Business Information

CL 158873

© 1993 Cirrus Logic, Inc.

Last but not least, overlay scheme doesn't answer question about realtime video capturing - just to be able to write video data on the disk we'll have to compress it (at least, 3:1 ratio).

Some modifications of overlay scheme using custom video bus on the input side of VGA memory (not output side, as traditional overlay does). This potentially will simplify genlocking and can provide a possibility to use VGA memory for deinterlacing of video image. Disadvantages: live video will generate huge memory bandwidth requirement, which, in turn, will limit size and/or FPS of live video; this limitations can lower quality of live video image to unacceptable level (we talking about product which will be in production in 1994 (hopefully)). Also, cost of this approach on LCD controller side will be significant - large FIFOs for ALL components, for example. Seems like this way is costly and provide limited quality; from our point of view, quality limitations are the real killer of this scheme.

There is other way to get live video: real time data compression/decompression. This way have several advantages - LCD controller doesn't required additional IO pads; since all data transfer happens through the system bus, there is no need for special video bus to compare with overlay scheme; this way is natural for applications which required real-time video capturing; embedded cost of decompression can be very low (in case of highly asymmetric coding/decoding methods). This approach isn't popular for desktop applications because of higher overall subsystem cost to compare with overlay scheme; but for laptops and notebooks it can be really attractive. For our understanding, main advantage of this way is ability to separate cost from LCD controller and basic system configuration PC (means if user doesn't want to pay for live video option he'll not have to). If video subsystem can be done as PCMCIA card, PC design will not be affected at all (some BIOS mods may be nessessary, of course). Also, decompression capability of LCD controller can be very usefull for video clip playbacks and truecolor still image viewing in color mapped environment (for example, user will be running Mode 12 for Windows perfomance reasons but it still will be possible to view truecolor (24 bits/pel) images in one or more windows. Also, in case some customers doesn't want live video at all, it's possible to disable decoder by using bonding option without substantial price increase (may be usefull for marketing guys).

Page 4

Some disadvantages do exist, though. First of all, currently popular "professional" compression schemes like MPEG, JPEG2, P64 etc. are very costly from hardware point of view and they are more or less symetric - this means, decoder and encoder are based around common part (like DCT transformer, for example). Currently, it's seems quite unrealistic to make MPEG-style decoder under \$2.00 (especially, if we're talking about adding this stuff to LCD controller with die size around 380 mil/side). It also will introduce power consumption problem.

Some "cheap" methods are asymetric in general (like

Cirrus Confidential  
Business Information

CL 158874

CinePack, for instance) and can be done in reasonably inexpensive way (probably under \$2.00); but seems like all of them have image quality problem. Most of this methods assume small size of image (from 160x120 pels to 320x240 pels); also, most of them can deal with update speed less than 20 FPS (in general 15 FPS is not bad). Most of this compression schemes usually have relatively poor intraframe compression performance which is compensated by high interframe compression ratio (for example, in CinePack key frame will be transmitted once out 15 frames). This can create highly visible quality loss for dynamic-type of video data (sport footage, for example).

## 2.2 WHICH WAY TO GO?

We think, approach with data compression definitely has advantages for laptop-type machines, especially if it can be done under \$1.00 of cost embedded to LCD controller. The later requirement was forcing us to find some inexpensive way for video compression/decompression. The target compression ratio was assumed to be between 8:1 to 10:1 (for 24 bits/pel video data). This will generate system bus data flow about 3 Mbytes/sec for 640x480 picture at 30 fps. This compression scheme doesn't need to be compatible with existing methods as long as somebody provide inexpensive encoder for this compressor (this is closed circuit type of system). Also, most expensive part of decoder (like YUV->RGB converter) can be shared with CinePack decoder for CD ROM playback.

© 2000 Cirrus Logic, Inc.

Page 5

## 2.3 SUGESTED ARCHITECTURE (SYSTEM LEVEL)

Let's assume we have (really) inexpensive decoder of compressed live video data which can provide reasonable image quality (remember, goal is LD quality (worst case, SVHS or Hi8 type VCR)). Let's also assume, we are getting this data through local bus on i486-based machine. The source of this data will be PCMCIA card plugged into standard PCMCIA host adapter (like Cirrus 6710). Now we're ready to calculate some figures:

Image size is 640x480 pels;  
total number of pels is 307200 per frame (300k);

Lets assume, we have dumb coder with 3bit/pel compressed data without any interframe compression (8:1 intraframe compression). This will give us following data flow rate:

307200 pels/frame = 921600 bits/frame = 115200  
bytes/frame;

At 30 FPS this will give us

115200 \* 30 = 3456000 bytes/sec = 3375 kbytes/sec =  
3.296 Mbytes/sec.

Cirrus Confidential  
Business Information

CL 158875

For local bus this data rate is a peanuts. For i486 this is also not a problem, especially if we gonna use MOV\$/INS/OUT\$ type of instructions (sorry, mnemonics may not be correct - we mean string move and string IO). How's about PCMCIA?

Pessimistic timing option for PCMCIA is based on standard ISA timing; let's check this case to see some worst-case limitations:

We assume 80ns Address Setup, 280ns command time and 40ns Address hold time (normal ISA timing). This yield 400ns typical cycle time and 5MBytes/sec bandwidth for 16bit wide access.

So, even with "safe" timing assumption compressed video data can be easilly transferred over PCMCIA port.

All this calculations show the possibility to implement suggested architecture on the system level.

Page 6

#### 2.4 THAT WILL BE GOING ON INSIDE LCD CONTROLLER

---

Let's calculate memory interface bandwidth requirements for case under consideration. We'll assume 32-bits wide memory data path and worst case for videocontroller and frame buffer activity - SimulScan and Color Dual scan STN panel.

We'll also assume FIFOs are based on threshold-triggered arbitration policy and have reasonable depth (like 16 or 24 levels). For simplicity we'll also assume fixed threshold equal to half of the fifo size.

To be on a safe side, we'll assume Vertical retrace time and most part of horizontal retrace time will be used exclusively for refresh, fifo prefetch and hardware cursor access. This will give us pessimistic estimation of bandwidth requirement. Now, lets calculate total number of Read/Write cycles per line.

Compression scheme we trying to play with is based on 4x4 pels block for luma channel and 8x8 pels block for chroma (4:1:1 chroma subsampling). Each block will be encoded into 32 bits long record (1 DRAM cycle per block, actually). Lets also assume decoder are REALLY dumb and will fetch chroma blocks for each line: this will greatly simplify decoder/sequensor design (remember, we have to be under one buck!), even if it will introduce some bandwidth loss (we will read two times more chroma data as we really need). For single frame 640x480 pels we'll need:

160x120 = 19200 blocks Y (luma)

Cirrus Confidential  
Business Information

CL 158876

80x60 = 4800 blocks U (chroma)

80x60 = 4800 blocks V (chroma)

Total number of blocks per frame is:

19200 + 4800 + 4800 = 28800 blocks

Now, for 8 lines of data (640 pixels each) we will need to write:

320 blocks Y + 80 blocks U + 80 blocks V = 480 blocks.

Thus, total number of write cycles per 8 lines will  
be:

480 W cycles. (average is 60W per line).

On the read side, we got some bandwidth wasting due to simplicity of decoder design. So, lets calculate number of read cycles on per line basis (our decoder doesn't have any interline memory).

Page 8

For each line we have to read:

blocks/line                  160 blocks Y + 80 blocks U + 80 blocks V = 320

(remember, 1 block = 1 memory access).

By adding average 60 words writing per line, we'll get:

320R + 60W = 380 cycles/line.

The other major player on DRAM side is frame buffer. For DSTN  
(worst case for us) we will need:

Each line is 640x3 = 1920 bits in and out.

This will give us 60 write cycles and 60 read cycles;  
total will be:

120 cycles/line

**Cirrus Confidential  
Business Information**

So, for each line we have to perform

120FB + 60CPU + 320VIDEO = 500 cycles / line.

**CL 158877**

CONFIDENTIAL

How long it will take for us to make 500 DRAM cycles? Lets assume we're running on 50MHz (just for simplicity, because MCLK period will be 20ns). Also, lets assume we will do at least 12 CAS cycles per RAS cycle (i.e. FIFOs are seating at the threshold of 12 and have normalized depth of 24). Now:

We'll need  $500 / 12 = 41.6(6)$

Thus, worst case we'll have to do

42 RAS cycles / line.

Each RAS cycle wasting 5 MCLKs, so total loss is

$42 * 5 = 210$  MCLK / line.

Each CAS cycle is 2 MCLK.  
To do 500 CAS cycles we'll need

$500 * 2 = 1000$  MCLK / line.

Total number of required MCLKs is:

$1000$  CAS +  $210$  RAS =  $1210$  MCLKs / line.

If we're at 20ns MCLK period, this yield:

$1210 * 20$  ns =  $24200$  ns / line.

#### Page 9

This is fine, because active part of line in SimulScan mode is about 28200 ns. So, we have about 4000 ns of spare time per line for good CPU side performance. Also, note we're not using retrace time at all; LCD controller will do all housekeeping activity at that time (prefetches, hardware cursor/hardware icons fetching, refresh, etc). Also, it will give us about 8% of unused vertical retrace time to improve CPU side performance (Winmark), because standard VR is 45 lines out of 525 total (8.57% of Vertical total) and we're not using it completely.

Can we do the same thing at 44MHz MCLK? This is important questions, because current -70 DRAMs cannot run on 50MHz safely.

At 44MHz we'll have 22.72 ns MCLK period.

We need 1210 cycles, so

$1210 * 22.72$  ns = 27500 ns exactly.

Cirrus Confidential  
Business Information

This will give us about 700 ns less than active display time. So, we definitely can run at 44MHz even with very pessimistic model.

How we can exploit the difference between pessimistic and

CL 158878

realistic models? There are two ways to go - performance improvement and/or FIFO size reduction. Our calculations shows that it is possible to use FIFOs with normalized depth of 16 (threshold at 3) and still get some additional performance improvement for Windows.

### 3. HOW WE CAN IMPROVE THE SITUATION

---

We believe, with reasonable increase of complexity of decoder (still probably under one dollar), it's possible to reduce data rate to 2bit/pel (24 bits/block) by using intraframe compression only (compression rate is 12:1). (we have some working ideas about it). For us it's seems highly desirable to avoid interframe compression at that time, because it unavoidably will increase decoder price (may be, up to two bucks??) and Windows driver complexity. But, worst case, we can do this to avoid average reduction 2:1 (total 24:1 compression rate). The question is - is it worth to do this or not?

We're not talking about 64bits wide memory data path - this is simple and obvious case; but, still, this live video scheme can be justified even in this high-end architecture. The oposite case - 16bit wide DRAM path - has potential limitations and doesn't seems a good way to go (also, it's possible to have reduced size live video (320x240 at 30FPS) even on this type of machines).

One thing - live video option will require some special shading methods to avoid slow response for highly dynamic video images. This is true for both STN Mono and STN colors (espesially, for single scan types). Color TFT support is not an issue, of course.

For live video capturing it still can be tough to put 3.5 Mbytes/sec on a hard drive (at least, on low-end machine). This is why 24bit/block option may be worth to implement, espesially on encoder side.

Page 10

### 4. CONCLUSION

---

The scheme, described in this memo seems to be possible to provide inexpensive high-quality live video option for next generation of Cirrus LCD controllers (like Nordic (or Nordik??)). The video subsystem will consists of small (under 2K gates total) decoder on the board of LCD controller and moderate-complex (under 10K gates) encoder/deinterlacer/scaller chip for PCMCIA cards.

Also, it seems like proposed scheme has a lot of advantages over "classic" overlay scheme in laptop environment.

It may be worth to try!

-----\$\$\$\$\$-----

Cirrus Confidential  
Business Information

CL 158879

9/13/93 -  
 Live video NOT  
 working -  
 "still being worked  
 on"

**NORDIC ACTIVITY AND RESOURCE PLANNING**

by Rakesh Bindlish and Vlad Bril rev.1 July 20, 1993

The main activities in NORDIC1M include the following:

For each new feature in the data base:

- a. Design, Architecture, Register Specifications and the Product Implementation Plan.
- b. Technology development and validation via bread-boarding.
- c. Learning of database AVGA3BR1.
- d. Design of new piece of logic.
- e. Implementation of new logic in schematics.
- f. Environment preparation and verification of new logic by itself.
- g. Design Review, timing analysis of critical pathes, static circuit analysis.
- h. Full chip environment, initialization and verification.
- i. Test Vector generation (which can be started after the TapeOut).

For the entire chip, to be done once:

- a. Regression porting from 5428 and development for new logic.
- b. Preliminary and final routing.

**The new logic in the absolutely basic feature set (priority A)**

(x/y analysis and design/implement and verify):

- a. Pin-out and top level. 1/1 DP
- b. 32bit CPU bus. 2/1 PP
- c. PCI (Peripheral Controller Interconnect) bus interface. 3/3 PP
- d. Modify the existing logic for Power Management (no light sleep support). 4/4 DP/VB  
Includes low power in suspend and stand-by and mixed voltage support and Green PC support.
- e. Flat Panel support: TFT, single scan STN monochrome and color, dual scan STN mono and color, CRTC modifications for panel and elimination of light sleep logic. 4/5 SdK
- f. Half Frame Buffer logic, its address generation, sequencer modifications, address remap for 32bit wide memory (no light sleep) 4/5 SgK
- g. Half Frame Buffer logic, its address generation, sequencer modifications, address remap for 16bit wide memory (no light sleep) 1/2 NOT NOW.
- h. Text Contrast Enhancement 1/2 VB/DP
- i. Text Vertical Expansion 1/2 VB/DP
- j. BLT improvement: memory mapped I/O 1/1 PP
- k. Testability of different modules ---- will be designed along with the new logic. 5/5 MR
- l. Some fixes from AVGA3BR1 and some from 6225/6235. 2/2 all

Each of these design pieces include all or some of the above listed activities.

Total work weeks of what we plan to do: 62 for the basic set.

> 11 WW with 6 engineers > 2.5 months adding 2 months for a tape-out -> 4.5months

Cirrus Confidential  
Business Information

**Cirrus Logic, Inc. Confidential Information**

to tape-out at basic set -> tape-out mid 12/93.

Some of the new features which are still being worked out are:

- A. Limited support for 800x600 panels (TFT, STN, dual, single scan): includes 12 and 16 dot character support. - 2/2 SE,NH or NOT NOW
- B. Limited support for 1024x768 panels (TFT, STN, dual, single scan ?) 2/2 SE, NH or NOT NOW
- C. H/W Icon on top of h/w cursor with 32bit wide memory. 2/3 SgK
- D. H/W Icon on top of h/w cursor with 16bit wide memory. 1/1 NOT NOW
- E. BLT Improvements as in 5429. 2/2 RB
- E. Audio support for CS4215 with 32bit wide memory. 4/4 RB
- F. Audio support for CS4215 with 16bit wide memory. 1/2 NOT NOW
- G. Cine Pak h/w acceleration support with 32bit wide memory. 4/4 RB/SdK
- H. Cine Pak h/w acceleration support with 16bit wide memory. 2/2 NOT NOW
- I. Live Video Support with 32bit wide memory. 6/6 VB,SE or RB /DP, SE or RB
- J. Fast shading for live video and moving images. 2/2 SdK
- K. Cross-talk reduction Whisper chip support. 2/2 VB/MR
- L. Dual Display (resolution maximization). 6/8 NOT NOW
- M. Inking Plane . 4/4 NOT NOW
- N. Grey Shade Mapping Option 2/2 NOT NOW

Total work weeks of what we plan to do: 53 (or 45 without large panel support).

Grand Total : 115 WW (or 107WW without large panel support) for additions -> 4.8 months with 6 eng

Add 1 month final verification and 1 month routing and tape-out -> 6.8 or 7 months for the priority A and B features -> tape-out end 02/94. This is a sanity check for the schedules to follow.

Resources available for the design and implementation are

Rakesh, Sagar, Dwarka, Prakash, Sridhar and Murali.

Vlad and Sasha are working on the new features and their architecture.

### **PLAN FOR THE ACTIVITIES**

NOTE : Some percentage (not more than 25%) of time Sagar and Sridhar will be supporting 6225/6235.

Cirrus Confidential  
Business Information

PLAN WITH NEW FEATURES IN PARALLEL



- Notes:
- Assumes a new hire (junior design engineer) in mid August '93.
  - Bread-boards and development activity are needed for shading and dithering, live video and cross talk reduction.
  - We may need help from Dayakar's group to convert 6440 shader to Foster City methodology.

**Cirrus Logic, Inc. Confidential Information**

**Definition Issues:**

0. Decode all 32bits of CPU address or only 24 + Hi/Low MEM as Alpine ?  
Saves 6 pins which can be used for h/w configuration without external pull-ups  
or 24 bit TFT panel support.
1. High resolution panels 800x600 and 1024x768 support? TFT or STN or both ?
2. 16bit wide video memory support at the first tape-out?
3. PCI bus BIOS support by Nordic-1M.
4. 90C24 pinout compatibility.
5. Office Environment Dual Display support.
6. Video Port support was dropped.
7. Scaling and Interpolation for Cine Pak and live video.
8. Live Video Window Specification. Can we set a restriction of alignment over 8 pixel boundary?  
Can we program the live video window as a CRT-address-range ? If two windows overlap, have  
the driver modify the live video window address range?
9. H/W Icon: is vertical icon string good enough?
10. Grey shade mapping option ?
11. 24bit TFT panel support with 18bit RAM. Is this OK?
12. STN panels Cross-talk reduction on an external chip.
13. Live Video Compression chip on a PCMCIA board.

CONFIDENTIAL INFORMATION

**Cirrus Confidential  
Business Information**

Forward video with next port. Done with port in its memory.

## Our Live Video

07/07/93

Compressed live video deinterlaced comes on the CPU bus and it is placed in memory in a specified video memory address.

Can we use the C000 address space or A/B000 range relative to GR6 selection to map the v. window ~~deinterlace~~ (without I/O before each group of live video accesses)?

When live video is detected the CPU date path switches to pass through (extended 256 color).



You need to control the angle between the color first & the next colors = fine. By doing this you can make circulate the cold air from G.O. down.

If you don't the practice looks like color saturation, less.



Aug 3/3 - 1861

4

It is suggested

17 =  $\rightarrow$  Nov. 15



↑ ↑  
2nd & metal  
bars

**NATIONAL** 

**Cirrus Confidential  
Business Information**

**CL 214141**



$$t_{\text{cd}} + t_{\text{lcd}} = \frac{1}{65} \text{ us} + \frac{1}{20} \text{ us} = 523 \text{ us}$$

16 dots/das

$$523 / 16 =$$

$$8d \cdot 15 \text{ us} / 16, 8d \cdot 50 \text{ us} / 16$$

$$\frac{8d}{15 \text{ us}} + \frac{8d}{50 \text{ us}} = \frac{16d}{x}$$

$$15 \text{ us}, 45 \text{ us}$$



$$f_1 + f_2 = f_x$$

$$f_x = \frac{f_1 + f_2}{2} = \frac{65 + 20}{2} = 42.5$$

$$15, 15, 15, 45$$

$$3d + 1 = 4d \rightarrow \frac{1}{3} \cdot 65 \text{ MHz} = 21.7$$

## Cirrus Logic, Inc. Confidential Information

LIST of NORDIC-1M Activities as of 10/10/93 (marked 11/4/93)

- done->* 1. Half Frame Buffer 3W SgK
- done->* 2. 32bit VL and PCI bus 3W PP
- 60% ->* 3. 4bit/pel packed 2W DP (*not verified, needs set-up from Submarine*)
- done->* 4. WavePort 4W RB and MR
- 40%* 5. High Rez Panel support & New Panels & 10/12/16 wide fonts 5W SdK  
(*text is done, graphics 4bit/pel and 8bit/pel started. No 16 and 24bit/pel  
Do we have to do graphics expansion?*)
- 30%* 6. WavePort, 32bit bus, HFB and High Rez Panel Support Integration  
3W 1W DP with help from RB, PP and SgK
- 50%* 7. New Shader & Panel Improvements 2W SgK and SE
8. 50MHz VL bus 2W PP (in progress)
9. ~~MCLK Freq. Range / 5429 Sequencer & BLT Upgrades~~ 4W PP and SgK  
*Sub-total #1:#9: 27W and 35MW*
10. H/W Icon + its integration 5W PP
10. Motion Video Architecture with Video Port, Play-back and Sashapack
  - a. Window Control, Addressing, FIFO & Scan Line Replication 6W RB
  - b. YUV->RGB 2W SdK
  - c. Horizontal Zoom with average/interpolation & b,c integr 2W SdK
  - d.. 8b/pel RGB and 16b/pel RGB 1W PP
  - e. 4:2:2 YUV (16b/pel) and 4:1:1 linear (12b/pel) 1W PP
  - f. SashaPack 2W SgK
  - g. Video Port from Feature Connector, TFT panels only & Int. 4W SgK*Sub-total: 16W and 16MW*
- ~~11. PC98 support 2W PP~~
- 50%* 12. NTSC Out 1W DP (*top level done, CRTC modifications to be done later*)
- [14.] 3V RAMDAC and CLK Synthesizer 3W EI
- [15.] PAD IKOS model R&D  
*Sub-total logic design group: 3W and 3MW*
16. Integration of VMA 4W RB SdK
17. Verification and Regresion 4W All
- [18.] Place and Route 4W TH
19. Testability in new modules and verification 4W MR  
*Sub-total logic design group: 36W*

Total design group:  $35\text{MW}+16\text{MW}+3\text{MW}+36\text{MW}=90\text{W}$

Average per design-engineer with 6 design-engineers:  $90\text{W}/6=15\text{MW/DE}$

Average per design-engineer with 7 design-engineers:  $90\text{W}/7=13\text{MW/DE}$

Counting 3W in October (11:29), 4W in November (1:26), 4W in December (1:24), 4W in January '94 (3:29), we get 15W available for work. So, there should be enough time to tape-out Nordic-1M by the end of January '94.

Note: Orion related activity is assumed low level for the design team (AD should work and AE minimum modifications and it should work) !!

Cirrus Confidential  
Business Information

NORDIC-1M Development Plan as of 10/16/93



Cirrus Confidential  
Business Information

Cirrus Logic, Inc. Confidential Information

### Features Added Since 12/20/93

1. Self Refresh
  2. 8bit Mono TFT Support
  3. 32KHz Status Bit
  4. NTSC-OUT Support with Digital and Analog RGB Encoders
  5. 2070 Chip Select Decode
  6. Display Data Channel ?
  7. Memory Mapped I/O for BLT registers
  8. Clock Run PCI addition ? (I do not think we need it)
  9. Get BLT to work with the signature generator (12/15/93 Bernie, nice).
  10. 5429 FC timing (12/15/93, D. Keene or Keith)
  11. Overlay support for 7194 TV Decoder with scaling

#### **Features Taken out since 12/20/93**

1. 800x600 panel graphics expansion for 16bit/pel and 24bit/pel modes
  2. Assymmetric 512kx8 DRAM support
  3. MCLK Frequency upgrade at 3.3V
  4. 1kx768 panel support
  5. 5429 upgrades except for memory mapped I/O for BLT registers
  6. 12 and 16 dot fonts
  7. PC98 support beyond 5428

卷之三

**Cirrus Confidential  
Business Information**

NORDIC-1M Development Plan as of 11/04/93



Cirrus Confidential  
Business Information

Cirrus Logic, Inc. Confidential Information

LIST of NORDIC-1M Activities as of 10/10/93 (marked 12/10/93)

- |                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <u>done-&gt;</u>                  | 1. Half Frame Buffer <u>3W SgK</u>                                                                                                                                                                                                                                                                                                                                                                                                                            |
| <u>done-&gt;</u>                  | 2. 32bit VL and PCI bus <u>3W PP</u>                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 60% ->                            | 3. 4bit/pel packed <u>2W DP</u> ( <i>not verified, needs set-up from Submarine</i> )                                                                                                                                                                                                                                                                                                                                                                          |
| <u>done-&gt;</u>                  | 4. WavePort <u>4W RB and MR</u>                                                                                                                                                                                                                                                                                                                                                                                                                               |
| <u>65%</u>                        | 5. High Rez Panel support & New Panels & 10/12/16 wide fonts <u>6W SdK &amp; SE</u><br>( <i>text is done, graphics H &amp; V 4bit/pel and 8bit/pel done. No 16 and 24bit/pel</i> )<br><i>Still to be done:</i>                                                                                                                                                                                                                                                |
| <u>done -&gt;</u>                 | - Horizontal Centering & LLCLK generation independent of HSYNC 2W                                                                                                                                                                                                                                                                                                                                                                                             |
| <u>sch_entry -&gt;</u>            | - Vertical Centering for 800x600 and VSYNC independent 2W                                                                                                                                                                                                                                                                                                                                                                                                     |
| <u>sch.entry (no progr. -&gt;</u> | - New Dither Logic for all modes including 16b/pel & 24b/pel 1W<br>- 800x600 panels modes sim. set-up & verification 2W<br>- Orion-AD & Submarine fixes 1/2W                                                                                                                                                                                                                                                                                                  |
| <u>done-&gt;</u>                  | 6. WavePort, 32bit bus, HFB and High Rez Panel Support Integration<br><u>3W 1W DP with help from RB, PP and SgK</u>                                                                                                                                                                                                                                                                                                                                           |
| <u>30%-&gt;</u>                   | 7. New Shader & Panel Improvements <u>2W SgK and SE</u>                                                                                                                                                                                                                                                                                                                                                                                                       |
| <u>done-&gt;</u>                  | 8. 50MHz VL bus <u>2W PP (in progress)</u>                                                                                                                                                                                                                                                                                                                                                                                                                    |
| <u>9.</u>                         | MCLK Freq. Range / 5429 Sequencer & BLT Upgrades <u>4W PP and SgK</u>                                                                                                                                                                                                                                                                                                                                                                                         |
| <u>50%</u>                        | 10. H/W Icon + its integration <u>5.5W PP</u>                                                                                                                                                                                                                                                                                                                                                                                                                 |
| <u>50%</u>                        | 11. Motion Video Architecture with Video Port, Play-back and Sashapack                                                                                                                                                                                                                                                                                                                                                                                        |
| <u>40% (no progr.)</u>            | a. Window Control, Addressing, FIFO & Scan Line Replication <u>6W RB</u><br>b. YUV->RGB <u>2W SE &amp; SdK</u><br>c. Horizontal Zoom with average/interpolation & b.c integr <u>2W SE &amp; SdK</u><br>d.. 8b/pel RGB and 16b/pel RGB <u>1W SE &amp; SdK</u><br>e. 4:2:2 YUV (16b/pel) and 4:1:1 linear (12b/pel) <u>1W SE &amp; SdK</u><br>f. SashaPack <u>2W SE &amp; SdK</u><br>g. Video Port from Feature Connector, TFT panels only & int. <u>4W SgK</u> |
| <u>50%</u>                        | 12. PC98 support <u>2W PP</u>                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                                   | 13. NTSC Out <u>1W DP</u> ( <i>top level done, CRTC modifications to be done later</i> )                                                                                                                                                                                                                                                                                                                                                                      |
|                                   | [14.] 3V RAMDAC and CLK Synthesizer <u>3W EI</u>                                                                                                                                                                                                                                                                                                                                                                                                              |
|                                   | 15. Integration of MVA <u>4W RB SdK</u>                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                                   | 16. Verification and Regresion <u>4WX6 All</u>                                                                                                                                                                                                                                                                                                                                                                                                                |
|                                   | [17.] Place and Route <u>4W TH</u>                                                                                                                                                                                                                                                                                                                                                                                                                            |
| <u>done -&gt;</u>                 | 18. Testability in new modules and verification <u>4W MR</u>                                                                                                                                                                                                                                                                                                                                                                                                  |
| <u>done -&gt;</u>                 | a. Shader Signature Generation<br>b. MVA Signature Generation<br>c. WavePort<br>d. Update Testability in all the other modules,<br>add more signals & buffer existing ones                                                                                                                                                                                                                                                                                    |

Cirrus Confidential.  
Business Information

NORDIC-1M Development Plan as of 11/22/93



Cirrus Confidential  
Business Information

Cirrus Logic, Inc. Confidential Information

NORDIC-1M Development Plan as of 12/03/93



Cirrus Confidential  
Business Information

NORDIC-1M Development Plan as of 12/10/93



## Attachment C—Exhibit List

\*\*\*19920803: News Release from Dialog. Pixel introduced CL-PX2070 and CL-PX2080. Exhibit EX-304.

\*\*\*19930915: Fax from Dickinson to Fujii of Cirrus Japan providing slides about Alpine Mulitmedia for NEC.

\*\*\*19930915: Agenda for meeting with NEC. Nordic Discussed. Meeting appears to be at Cirrus.

\*\*\*199310XX: Computer Design Article on introduction of PX2085 Media DAC.

\*\*\*19931102: Meeting with Apple. Reported in Memo from Bob Conner to Del Mank et al. EX-543C. Apple “expressed interest in the Nordic Controller.” CL160010.

\*\*\*19931216: Power Point on Flat Panel Products. IBM Power Personal Systems (Location???. (Live Video Through the Host Bus—CL158886). PCMCIA card interface to video over bus.

\*\*\*19940106: Request for price quotes from IBM Japan.

\*\*\*19940107: Memo from Bril to Cirrus Japan answering technical questions on Nordic.

\*\*\*19940114: Memo from Bril to Cirrus Japan answering technical questions on Nordic.

\*\*\*19940114: Dickenson Price Quote on Nordic to IBM Japan. RX-553C. CL159503.

\*\*\*19940118: Memo from Bril to Cirrus Japan answering technical questions on Nordic.

\*\*\*19940122: Memo from Bril to Mary Johnson and Brian Howard at Apple showing questions about VB-Nordic-AP001. RX-567C.

DO NOT DESTROY  
19940122

8/3/92

EXHIBIT

PX-304

1/9/1 (Item 1 from file: 621)  
DIALOG(R) File 621: IAC New Prod.Annou. (R)  
(c) 1996 Information Access Co. All rts. reserv.

0334800  
News Release  
DATELINE: PLANO, TX August 3, 1992 WORD COUNT: 1467

CIRRUS LOGIC, Inc.  
3100 West Warren Avenue  
Fremont, CA 94538  
510-623-8300  
Fax: 510-226-2240

EDITOR CONTACT:  
Connie Duncan (510) 226-2346  
Joe Fowler (510) 226-2239

**PIXEL SEMICONDUCTOR ANNOUNCES BREAKTHROUGH FAMILY OF VIDEO CHIPS FOR MULTIMEDIA APPLICATIONS**

PLANO, TX. -- August 3, 1992 -- Pixel Semiconductor, Inc., a subsidiary of Cirrus Logic, Inc., (NASDAQ: CRUS) today introduced the CL-PX2070 and CL-PX2080, companion high-performance integrated circuits that process and display multiple streams of full-motion video for personal computer and video teleconferencing applications. The CL-PX2070 is a programmable digital video processor (DVP) that captures, stores, processes, and routes multiple streams of full-motion video. The CL-PX2080 MediaDAC (TM) chip is the industry's only RAMDAC that digitally mixes and simultaneously displays graphics with multiple independent streams of live video, allowing users to view and manipulate video windows as easily as today's graphics-based windows.

These devices provide the same powerful video processing technology that, until now, has been available only with complex, expensive hardware. They offer users all the advantages and capabilities of having information in a digital format. These include the flexibility to add and overlay graphics and text to video sequences, edit between single or multiple streams of video, and to display this data in multiple windows -- all in real time. This level of functionality, unique to the CL-PX2070 and CL-PX2080, is ideal for a range of "multimedia" applications.

The CL-PX2070 can be used with such VGA graphics controllers as Cirrus Logic's CL-GD5422 to provide cost-effective, yet powerful, VGA video capture and playback systems. Implementing the CL-PX2070 and CL-PX2080 together supports high-performance (1024-by-768-pixel) true color video authoring, video conferencing, and video teleconferencing systems.

"Market research estimates indicate that by 1996, 5.7 million units of full-motion video-capable PCs will be shipped, representing a dramatic increase over current demand," said Jim Fontaine, President

500054371 - 31032100

ATI023293

3000000000000000

of Pixel Semiconductor. "With the price/performance solutions offered by the CL-PX2070 and CL-PX2080, full-motion video capabilities will be propelled into the mainstream."

#### **CL-PX2070 Digital Video Processor**

The CL-PX2070 incorporates all the advanced digital video processing capabilities and features required to support and manage multi-stream video. It accommodates applications that require several concurrent video and graphic sources by providing four input/output (I/O) ports that can connect directly to multiple independent I/O devices, including the host system. Two of these ports can receive video from virtually any source by supporting a variety of data formats such as NTSC or PAL (the U.S. and European television standards) YUV-encoded data, or red, green, and blue (RGB) data. The third port interfaces to the host system through the Industry Standard Architecture (ISA) bus or the Micro Channel Architecture (MCA) bus. The fourth port connects to a video memory buffer.

To manage the flow of multiple streams of data, the CL-PX2070 offers bi-directional data paths between its ports and internal control and processing functions. These features enable the chip to process and simultaneously route digital video it receives from a decoder and from the host system to any connected device. For example, signals from a VCR can be sent to the frame buffer for immediate display and to the CPU for storage on a hard disk to implement simultaneous video preview and capture.

#### **Programmable Filters Perform Conversion and Provide Better Images**

To accommodate the different formats of various I/O devices, the CL-PX2070 features a programmable arithmetic logic unit (ALU) that performs all the necessary line interpolation and format conversions. The ALU enables implementing video filtering and scaling functions for mapping video to a particular window size or to the format required by an I/O device. With the CL-PX2070's scaling capability, video images from the NTSC-size frame can be resized down to the smaller Common Interface Format (CIF) video standard for outputting to a video I/O device. Conversely, using the CL-PX2070's scaling controls to resize small frames up to screen size enhances video decompression. During scaling, interpolation filters operate to create "substitute" pixels, and to remove noise and redundant data to provide users with better-looking images.

#### **Memory Management and Editing Features Support Advanced Applications**

For applications involving editing and mixing functions, the CL-PX2070 features an advanced frame buffer controller that can hold multiple images. Based on memory capacity that can range from 256K bytes to 8M bytes of DRAM or VRAM, the frame buffer controller supports eight object buffer controllers, which allows storage of two "live" video streams and six renditions mixed with graphics and text. This capability lets users retrieve and transmit multiple streams of video and still data, a feature that is important for video authoring, video editing, and video teleconferencing applications.

The CL-PX2070's ALU lets users create a variety of video transition and overlay effects. Video streams can be transitioned using modes

00000727 - 2003400

that include fades, wipes, blends, or cuts, into a second video stream or mixed with text and graphics to give users advanced editing capabilities. By programming the chip's overlay controls, images can be superimposed to create special effects. For example, particular images can be isolated and blended to provide a "weatherman effect," as seen on television weather reports. Other special effects functions the CL-PX2070 performs include flipping and mirroring images.

#### CL-PX2080 MediaDAC Chip

The CL-PX2080 augments the CL-PX2070 with advanced features and capabilities that include a 24-bit digital-to-analog converter (I?AC), two sets of color look-up tables, digital mixer, video window zoom hardware, color space converter, and a hardware cursor. It features two input ports, one for full-motion "live" video and one for graphics data, and an output to drive the CRT. The live video port accepts either YUV or RGB data. The graphics port accepts RGB data only, supporting standard 8-bit VGA or 8-, 16-, 24-bit data through a 32-bit parallel graphics port from the system graphics controller, such as a Super VGA or XGA graphics controller. The CL-PX2080 connects directly to the ISA and MCA bus for initialization and control by the host CPU.

Running at clock speeds of up to 85 MHz, the output of the CL-PX2080 easily accommodates the update rates of full-motion video and high-resolution color graphics on non-interlaced CRTs at resolutions of up to 1024 x 768 at 72 Hz refresh. It permits the system to use a

COMPANY: Pixel Semiconductor

Cirrus Logic

PRODUCT: ICs by Function NEC (3674199)

TRADE NAME: CL-PX2080 MediaDAC; CL-PX2070

EVENT: Product Design & Development (33)

COUNTRY: Texas (1548); TX (1548)

SPECIAL FEATURE: Price

ATI023295

9/15/97



**CIRRUS LOGIC**

**FACSIMILE MEMORANDUM**

**EXHIBIT**

RX-541 C

To: Kimio Fuji  
Cirrus Logic K.K.  
Fax Nbr: 81-3-3340-9120

From: Bob Dickinson  
Fax Nbr: 510-226-2250

Subject: Alpine Multimedia

Date: September 15, 1993

cc: Bill Chu, Jeff Diamond, Bill Knapp, Tony Man, Takeo Wada, Brent Wientjes

---

We did not have time to cover our multimedia integration plans for Alpine with NEC in detail. Please convey the attached material to Onodera-san and Mino-san and let us know if they want to discuss this in more detail.

Best regards,

DRAFT - PROTECTIVE ORDER

**Cirrus Confidential  
Business Information**

# Graphics & Multimedia Integration Market Needs

|            |          |          |
|------------|----------|----------|
| CAPABILITY | PLAYBACK | AUDIO    |
|            | CAPTURE  | VIDEO    |
|            | EDIT     | GRAPHICS |
|            | PREVIEW  |          |

- ◆ High Performance within Windows Environment

- ◆ Cost-effective
- ◆ Low Part Count
- ◆ Migration to Motherboard

- ◆ Tolerant to Evolving Standards

Cirrus Confidential  
Business Information

CL 159667

# Graphics & Multimedia Interface Technology Requirements



Cirrus Confidential  
Business Information

CL 159668

# Graphics & Multimedia Integration Digital Video under Windows



# Graphics & Multimedia Integration Video Playback Issues

- ◆ User Experience determined by:
  - ◆ Image size and resolution
    - 1/4 screen or larger
    - 30 fps or higher
    - 16 bps or higher
  - ◆ Frame rate
  - ◆ Pixel Color Depth
  - ◆ Compression/processing artifacts
- ◆ Performance Factors
  - ◆ User Platform
    - ◆ CPU System Bus
    - ◆ CD ROM, Hard Disk Speed
  - ◆ Multimedia Content
    - ◆ Compression Schemes
      - ◆ Type of Video Material
      - ◆ Compressive Ratio/Efficiency
    - TV quality or better
      - Wide selection
      - Need 20:1 / or better
- ◆ Cost of Acceleration for Digital Video
- ◆ Audio Synchronization

Cirrus Confidential  
Business Information

CL 159670

# Graphics & Multimedia Integration Playback Bottlenecks

- ◆ Data Rates from Storage Medium
  - ◆ CD ROM: 150-300 KB/sec today
  - ◆ LAN: Less than 300 KB/sec today
- ◆ Decompression
  - ◆ Algorithm Choice
    - ◆ Efficiency, data loss, artifacts
    - ◆ Cost of hardware acceleration
- ◆ Scaling
  - ◆ High quality Scaling is compute intensive
  - ◆ Pixelation often problem with software scaling and Pixel doubling
- ◆ Rendering
  - ◆ Graphics frame buffer Interface
  - ◆ Bit BLT Modes
- ◆ High Processor usage for Audio

Cirrus Confidential  
Business Information

CL 159671

Page 7  
Version 1.0



CIRRUS LOGIC

# Graphics & Multimedia Integration Playback Hardware Acceleration

- ◆ High Speed Buses
  - ◆ CPU - Graphics Interface
    - ◆ 32 bit Local Bus - VL or PCI
  - ◆ Graphics - Video Memory Interface
    - ◆ Wide Bus - 64 bit DRAM or 32 bit VRAM
    - ◆ 45-60ns Memory Technology
- ◆ Efficient Graphics Engine
  - ◆ Windows Acceleration
  - ◆ Decompression Acceleration (Evolving Standard Tolerant)
  - ◆ Scale / Zoom
  - ◆ Masking
- ◆ Intra Frame Hardware Processing
- ◆ Unified Frame Buffer
  - ◆ Color Space Conversion YUV-RGB
- ◆ Audio Synchronization Support

Cirrus Confidential  
Business Information

CL 159672

# Graphics & Multimedia Integration Roadmap



Graphics Board



Video Board



Audio Board

ISA Bus  
> 50 Chips  
3 Separate Slots

1H93

40 Chips  
1 Slot

2H93

< 20 Chips  
1 Slot

1994



VL Bus



VL or PCI Bus

Cirrus Confidential  
Business Information

CL 159673

# Alpine - Video



- 30 fps Live Video Window
- Graphics Color depth independent of Video Color depth  
(24-Bit Video, 8-Bit Graphics)
- 30 fps 320 x 240 x 16 Video Capture via VL or PCI
- 30 fps 320 x 240 Video Playback
- 2x or 4x Interpolated zoom of Playback
- CinePAK Decode
- Video Port compatible to VAFIC or Media Channel

Cirrus Confidential  
Business Information

CL 159674

CIRRUS LOGIC

## Integrated Sound





**CIRRUS LOGIC**  
**FACSIMILE MEMORANDUM**

To: Kimio Fuji  
Cirrus Logic K.K.  
Fax Nbr: 81-3-3340-9120

From: Bob Dickinson  
Fax Nbr: 510-226-2250

Subject: Alpine Multimedia

Date: September 15, 1993

cc: Bill Chu, Jeff Diamond, Bill Knapp, Tony Man, Takeo Wada, Brent Wientjes

We did not have time to cover our multimedia integration plans for Alpine with NEC in detail. Please convey the attached material to Onodera-san and Miro-san and let us know if they want to discuss this in more detail.

Best regards,

Number of pages, including cover letter 10

**TRANSMISSION REPORT**

THIS DOCUMENT (REDUCED SAMPLE ABOVE)  
WAS SENT

\*\* COUNT \*\*  
# 10

\*\*\* SEND \*\*\*

| END   | REMOTE STATION I.D. | START TIME     | DURATION | #PAGES | COMMENT               |
|-------|---------------------|----------------|----------|--------|-----------------------|
|       | 81333409120         | 9-15-93 4:01PM | 7'56"    | 10     |                       |
| TOTAL |                     |                | 0:07'56" | 10     | XEROX TELECOPIER 7021 |

Cirrus Confidential  
Business Information

CL 159676

9/15/93

(Where)

## A G E N D A

**NEC MEETING**  
September 15, 1993  
9:30am - 12:00n

EXHIBIT

RX-592C

- Introduction Dickinson
- Cirrus Logic Overview
- NEC Requirements NEC
- Media Manager<sup>TM</sup> Demo Brasfield
- 542x/Alpine/Northstar Roadmap Man
- 64 Bit Architecture Chu
- Multimedia Integration Wientjes
- Nordic Talreja
- Wrapup All

CONFIDENTIAL

Cirrus Confidential  
Business Information

CL 159677

## AGENDA

September 15, 1993

1. Price Projection for GD5428 in Q1/Q2, 94
2. Production Status for GD5428
  - (1) Current Production Volume
  - (2) Current Lead Time
3. Manufacturing Status
  - (1) Wafer Fab. Site
  - (2) Assembly Site
  - (3) Influence of Simitomo Explosion
4. Sales Status for GD5428
  - (1) Sales Volume
  - (2) Major Users
5. Cirrus Financial Status / Q3/Q4 of CY93
6. Questions for Cirrus Products
  - (1) Alpine Availability
  - (2) Future Plan of Cirrus Products After Alpine
  - (3) Future Possibility of Adopting 32Bit Memory Mapped Register

CONFIDENTIAL - 100-1000

Cirrus Confidential  
Business Information



**CIRRUS LOGIC**

## **INTERNAL MEMORANDUM**

To: Eve Brasfield, Bill Chu, Jeff Diamond, Tony Man  
Prem Talreja, Brent Wientjes

From: Bob Dickinson

Subject: NEC Agenda

Date: September 14, 1993

cc: Doug Bartek, Del Mank, Keith Uhlin

---

Attached is the agenda for the NEC meeting tomorrow. Your time budget is noted in parenthesis. The meeting will be held in the Sales conference room.

Let me know if you have any questions.

Best regards,

*Bob*

*Jeff & I  
Liz, etc  
distribution*

CONFIDENTIAL

**Cirrus Confidential  
Business Information**

**CL 159679**



**CIRRUS LOGIC**

**INTERNAL MEMORANDUM**

To: Eve Brasfield, Bill Chu, Jeff Diamond, Tony Man  
Prem Talreja, Brent Wientjes

From: Bob Dickinson

Subject: NEC Agenda

Date: September 14, 1993

cc: Doug Bartek, Del Mank, Keith Uhlin

---

Attached is the agenda for the NEC meeting tomorrow. Your time budget is noted in parenthesis. The meeting will be held in the Sales conference room.

Let me know if you have any questions.

Best regards,

*Bob*

**Cirrus Confidential  
Business Information**

**CL 159679**

## A G E N D A

**NEC MEETING  
September 15, 1993  
9:30am - 12:00n**

- Introduction (10 mins)
- Cirrus Logic Overview Dickinson (10 mins)
- NEC Requirements NEC (10 mins)
- Media Manager<sup>TM</sup> Demo Brasfield (30 mins)
- 542x/Alpine/Northstar Roadmap Man (30 mins)
- 64 Bit Architecture Chu (15 mins)
- Multimedia Integration Wientjes (15 mins)
- Nordic Talreja (30 mins)
- Wrapup All

CONFIDENTIAL INFORMATION

Cirrus Confidential  
Business Information

CL 159680

## A G E N D A

**NEC MEETING**  
**September 15, 1993**  
**9:30am - 12:00n**

- Introduction Dickinson
- Cirrus Logic Overview
- NEC Requirements NEC
- Media Manager<sup>TM</sup> Demo Brasfield
- 542x/Alpine/Northstar Roadmap Man
- 64 Bit Architecture Chu
- Multimedia Integration Wientjes
- Nordic Talreja
- Wrapup All

CONFIDENTIAL - 1993

Cirrus Confidential  
Business Information

CL 159681

10/93

EXHIBIT

RX-306

## Technology and Design Directions

Designers of DSP and VLSI chips

Search continues for a single  
best approach to DSP interfacing

Realtime OSs seek more  
functions and standards

When you scan a book  
please don't forget to stamp it.  
2 3 4 5 6 7 8 9 10

MIT LIBRARIES  
JUL 21 1993  
BARKER

Inside this issue

**OEM Integration Supplement**



ATI020428

## RAMDAC adds video to PC graphics subsystems

Designers of graphics subsystems for the PC have been achieving to add value to their products. Video is the obvious answer, but a lack of any PC graphics/video standard, and the cost of duplicate circuits has kept the video and graphics on separate boards. To address these problems, the Pixel Semiconductor subsidiary of Cirrus Logic has introduced the Px2085 MediaDAC, a 135-MHz, 24-bit RAMDAC, which is the first to pro-

mixing of high-resolution graphics and full-motion video. The YUV to RGB color space converter delivers 24-bit full-motion video and saves video memory. Look-up-tables on the chip allow brightness and contrast control at 1280x1024 resolution. Other advanced features include tag position, individually zoomable windows, interpolated zooming and single pixel resizing precision.

More than a generic RAMDAC the

on-board. Through a 32-bit data bus, the VPU inputs digitized RGB and YUV video data from a wide range of formats. The VPU handles such functions as zoom control, format alignment, chrominance interpolation and color space conversion. The VPU contains a programmable gamma corrector lookup table.

On the graphics side, the GPU accepts graphics data through a VGA interface or from VRAM. As a result, the MediaDAC can support the large installed base of 8-bit serial VGA hardware and VGA-compatible software, while at the same time support next-generation systems that need to read from a 32-bit VRAM serial data port.

The MediaDAC implements a three-color hardware cursor. The CBCU on the chip controls the cursor color, pattern, and position of the cursor. It also defines the characteristics of screen window borders.

Video and graphics come together at the MIU. The MIU contains circuitry which the video and graphics both require to get onto the screen. These include three video-speed 8-bit DACs, internal comparators that provide sense function and synchronous alignment logic.

The MediaDAC is register compatible with Brooktree's popular Bt485 RAMDAC and will interface with all video cards that implement the VAFCS standards. The chip is packaged in a 160-pin quad-flat-pack. Available in samples this quarter, the chip is expected to be in volume production in early 1994. The price is \$50 (1,000s).

—Jeff Child



*The Px2085 MediaDAC is a highly integrated graphics chip with built-in digital-to-analog conversion. The chip offers a cost-effective way to add video capabilities to graphics boards. Cost is saved by allowing video and graphics functions to share the same D-A converters, color converter, and multiplexing circuitry. (The diagram shows video functions shaded.)*

vide video-ready functions and VESA Advanced Feature Connections (VAFCS) compatibility on a single chip. The Px2085 MediaDAC offers an easy design transition for board designers interested in adding video-ready functions to their graphics boards. Pixel's strategy is to let the video and graphics functions share the same D-A converters, color converter, and multiplexing circuitry.

The Px2085 supports four full-motion video windows, which can be independently occluded. The MediaDAC enables the full digital

MediaDAC is a highly integrated graphics chip with the digital-to-analog conversion built-in. The MediaDAC comprises six functional blocks: a host interface unit (HIU), video processing unit (VPU), graphic processing unit (GPU), cursor border control unit (CBCU), overlay control unit (OCU), and monitor interface unit (MIU).

The HIU connects the MediaDAC directly to ISA and MCA buses. Eliminating costly interface glue logic, the HIU decodes a 16-bit address and responds as an 8-bit peripheral. The HIU also interfaces with hardware

### MediaDAC at a glance

- VESA Advanced Feature Connector compatible
- 135 MHz pixel clock rates
- Supports wide range of RGB and YUV video formats
- Supports graphics input from VGA or VRAM
- 64x64-pixel hardware cursor
- Direct interface to ISA and MCA buses

**Pixel Semiconductor**  
Cirrus Logic  
3100 W. Warren Ave  
Freemont, CA 94538  
(510) 623-8300  
Circle 246

11/02/93

*LCD Drive*

CIRRUS LOGIC, Inc., 3100 West Warren Avenue, Fremont, CA 94538 Telephone: (510) 226-2289 Fax: (510) 226-2289



CIRRUS LOGIC

To: Del Mank  
 Mike Callahan  
 Tim Blankenship  
 Steve Bily  
 Chris Ludden  
 Sunder Velamuri  
 Peter Pranys  
 Bill Chu  
 Doug Bartek  
 Mike Kabealo  
 Dan Hauck  
 Bill Caparelli  
 Bob Dickinson

cc: From: Bob Conner  
 Subject: 11/2/93 Apple Meeting  
 Date: November 11, 1993

|                                                                                                                                                                                                                                                                                                                                       |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Mail Stop: B2-633<br>Crystal Fax #512-462-3352<br>Crystal Fax #512-462-3352<br>Crystal Fax #512-462-3352<br>Crystal Fax #512-462-3352<br>Mail Stop: B2-541<br>Fremont Sales Office<br>Mail Stop: B2-630<br>Mail Stop: B2-630<br>Mail Stop: B1-710<br>Mail Stop: B1-706<br>Mail Stop: B1-700<br>Mail Stop: B1-902<br>Mail Stop: B2-541 |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

EXHIBIT

RX-543 C

00005424-10000000

Executive Summary:

During the LCD Drivers' Strategic Plan presentation last month, we discussed the need for the "OEM pull-through strategy" execution to create a demand for our LCD drivers (via getting major systems OEMs to ask their vendors -- our customers -- for LCDs using our drivers). On 11/2/93, we discussed our LCD driver products (under N.D.A.) with Apple's Portable Display Engineering and Advanced Display groups. The meetings were very successful! Highlights:

- Portable Display Engineering has RFQ's out to all major LCD vendors for:
  - 640x480 256K color TFT LCD (production in 10/94) -- highest priority
  - 800x600 256K color TFT LCD (production in 10/94)
    - Apple would like to be the first notebook OEM to offer a notebook with this LCD; however, it's lower in priority than the 640x480 LCD.
- Portable Display Engineering liked our Peanuts driver and will contact their vendors (Hosiden was specifically named) regarding availability of a Peanuts-based LCD!
- Advanced Display is exploring developing a 12" 256K-16.7M color TFT LCD monitor product, which must be priced <\$3,000. The mass production timeframe (e.g., CY '95 or CY '96) is dependent on Apple obtaining a color TFT LCD cost enabling hitting this price point.
- Advanced Display liked the Woodstock/Snoopy feature set, particularly color matching. They are interested in working with us to resolve the LCD module interface bottleneck.
- Advanced Display wants to discuss with Cirrus Logic an idea that may significantly increase graphics performance. (Apple wants to employ this idea first in a CRT-based product).

Attached is an ad for the new PowerBook Due 270c, which features "16-bit color -- an industry first." I believe this notebook uses Sharp's 18-bit color TFT LCD (although we did not discuss this).

I would like to thank Peter Pranys for setting up these visits. We should plan to visit additional major OEMs, particularly once we receive a Peanuts-based LCD (expected in 1/94).

Cirrus Confidential  
 Business Information

Number of Pages in this transmission including cover sheet 5

1

CL 160008

# Everything you've always wanted in a PowerBook.



Introducing the PowerBook Duo 270c.

000000000000000000000000

The new Apple® PowerBook Duo™ 270c and PowerBook Duo 250 may be two of the lightest notebook computers you can buy today. But that didn't stop us from giving you the world.

They're surprisingly bright, remarkably comfortable, and they run longer than just about any other PowerBook. Without compromising

on power, speed or expandability.

At a mere 4.2 pounds, the sleek PowerBook Duo 250 is the lightest notebook you can buy with a backlit, active-matrix display. Delivering sharp, presentation-quality images.

Not to be outdone, the new



4.8-pound PowerBook Duo 270c is the first notebook under 5 pounds with a backlit, active-matrix color display. And the only notebook computer in any weight class to provide stunning, 16-bit color. Which happens to be a new standard for the industry.

Meetings' Details:

Apple has three groups which are currently evaluating LCDs:

- Portable Display Engineering: evaluates/selects LCDs for Apples notebooks
- Advanced Display: evaluates/selects non-CRT display technologies for the Imaging group, which makes monitors, printers, scanners, etc.
- Newton: evaluates LCDs for PDA's. Dianne Colbert is the single display engineer.

Customer: Apple Computer – Portable Display Engineering

Date: Tuesday, Nov. 2, 1993

Attendees: Tom Credelle, Manager, Portable Display Engineering, Apple  
Steve Baily, Apple  
Peter Pranys  
Sunder Velamuri

- Submitted RFQ's out to all major LCD vendors for:
  - 640x480 256K color TFT LCD (production in 10/94) – highest priority
  - 800x600 256K color TFT LCD (production in 10/94)
    - Apple would like to be the first notebook OEM to offer a notebook with this LCD; however, it's lower in priority than the 640x480 LCD.
    - Said that this resolution fits Apple's system architecture, which already uses 1 MByte of video memory.
- May consider a 1024x768 TFT LCD with a digital interface for CY '95 notebooks.
- Expressed interest in the Nordic controller.
- Apple's application software has both a 15-bit/pixel mode and a 24-bit/pixel mode.
- Liked our Peanuts driver and will contact their vendors (Hosiden was specifically named) regarding availability of a Peanuts-based LCD!
- Suggested that we discuss Peanuts with OIS (said Chuck Wilson is a key Program Manager & Rex Tapp is the President).
- Liked the Woodstock/Snoopy features. Said that an upcoming Apple product will have the capability to adjust the contrast ratio/viewing angle via software (not hardware).
- Currently drive the LCD at 60 Hz (no CRT timing -- no horizontal & vertical blanking), because for "simulscreen" (i.e., simultaneously driving two different displays with the same -- or different -- images) currently use two separate graphics controllers and video memories.
  - However, in the near future Apple may eliminate one of the video memories to minimize cost, which implies that driving the LCD with CRT timing for "simulscan" may become important.
- See 1024x768 color TFT LCDs moving rapidly into overhead projectors.
  - With their current implementation using two separate graphics controllers & video memories, Apple can easily simultaneously drive different resolution LCDs (i.e., a built-in 640x480 LCD and an external 1024x768 LCD). However, a problem will occur if they eliminate one of the video memories.
- In response to our Peanuts roadmap, said that:
  - An LCD using a 6-bit driver and 1-level frame rate modulation will have acceptable display quality.

Cirrus Confidential  
Business Information

3

CL 160010

- A horizontal-stripe LCD has inferior display quality relative to a vertical-stripe LCD according to some human factors studies. Suggested that we contact Jim Larimer at NASA-Ames for some details on these human factors studies. (Said that OIS uses quad-green).
- Both Tom and Steve travel to Japan to meet with display vendors once per quarter.
- In some casual conversation over lunch, Tom expressed some disappointment with Sharp's "lack of responsiveness" regarding developing new TFT LCDs to meet market requirements.

Customer: Apple Computer - Advanced Displays

Date: Tuesday, Nov. 2, 1993

Attendees: Neil Bergstrom, Manager, Advanced Displays, Apple  
Dick Cappels, Display Engineer, Apple  
Peter Pranys  
Sunder Velamuri

- Advanced Display is exploring developing a 12" 256K-16.7M color TFT LCD monitor product, which must be priced <\$3,000. The mass production timeframe (e.g., CY '95 or CY '96) is dependent on Apple obtaining a color TFT LCD cost enabling hitting this price point.
  - Said that Apple will only introduce a new product if it's priced low enough to be high volume (i.e., Apple has no interest in serving niche markets).
  - Looking for ways to not only equal, but to exceed the CRT in order to justify the LCD's price premium.
  - Said that vendors will soon be achieving two 12" LCDs per motherglass.
- Advanced Display liked the Woodstock/Snoopy feature set, particularly color matching. They are interested in working with us to resolve the LCD module interface bottleneck.
- Regarding the LCD module interface,
  - Typical cable length is 1.75 to 1.9 meters.
- Advanced Display wants to discuss with Cirrus Logic an idea that may significantly increase graphics performance. (Apple wants to employ this idea first in a CRT-based product).
- Advanced Display is also studying non-LCD flat panel technologies:
  - When asked whether we are actively participating in the ferroelectric LCD market, I responded that we are working with Canon (the implication was with controllers, not drivers -- Apple understands ferroelectric LCDs are digital and create gray scales via error diffusion dithering). Apple seemed to think that ferroelectric LCDs are priced aggressively relative to TFT LCDs. There may be some opportunity for Northstar here, which requires some follow-up.
  - Said the Nippon Denso has developed an anti-ferroelectric LCD
  - Said that Fujitsu is making great progress with color plasma panels and the prices will decrease significantly in CY '94.
  - Looking at FEDs

Action Items:

- Send Dick Cappels information on Crystal's SmartAnalog (AR: Sunder/Peter).
- Provide a Snoopy & Woodstock spec to the Portable Display Engineering and Advanced Display groups after Fall Comdex (AR: Sunder/Peter).
- Get a mutual N.D.A. established with Apple's Advanced Display (AR: Peter).
- Set-up follow-up meeting with Apples' Advanced Display to: (AR: Peter):
  - Hear Dick Cappels' idea to significantly improve graphics performance.
  - Explore whether Apple is interested in a controller that supports ferroelectric LCDs
- Set-up meetings with the Portable Products Engineering, Advanced Display and Newton groups to demo a Peanuts-based LCD -- hopefully in 1/94 (AR: Peter).

200005471 403100



4000000000000000

**Cirrus Confidential  
Business Information**

**CL 160013**

12/93

EXHIBIT

RX-547 C

# Flat Panel Products

IBM Power Personal Systems

December, 1993 Meeting

CONFIDENTIAL INFORMATION

Cirrus Confidential  
Business Information

CL 158880

 CIRRUS LOGIC

Cirrus Logic Confidential  
N.D.A. Required

# Cirrus Logic VGA "Family Tree"



CL 158881

Cirrus Confidential  
Business Information

For Internal Use Only

1995

CIRRUS LOGIC

Cirrus Logic Portable Multimedia Presentation - December, 1993

Internal Use Only

# Key Multi-Media Technologies

| Audio Technology        |                        | Graphics Technology |                    | Video Technology |                   |
|-------------------------|------------------------|---------------------|--------------------|------------------|-------------------|
| Audio/Video Synch.      | Speech Recognition     | Music Synthesis     | Speech Synthesis   | Video Overlay    | Video Encoding    |
| Integrated Clock Synth. | Integrated RAMDAC      | High Resolution     | GUI Acceleration   | Video Decoding   | Video Compression |
| Audio Compression       | Audio De-Compression   | LCD Interface       | Power Management   | Video Windowing  | Video Overlay     |
| 16-bit DMA Interface    | 16-bit 44kHz PCM Audio | Mixed / Low Voltage | Expansion (PCMCIA) | Video Processing | Multiple Streams  |

## Audio Technology

## Video Technology

For Information Use Only



# Nordic Software Plan

- BIOS - within 2-3 weeks of first silicon arrival, BIOS should be ready for release to Alpha customer sites
  - Full feature 48K version or 32K modular
  - Supports new VESA VBE/PM & VBE 2.0 architecture
  - Extended modes (including 75Hz refresh) & 1st priority panel types
- Graphics Drivers
  - 8 & 16bpp Windows drivers available to alphas mid-March
  - AutoCAD & OS2/2.1 available mid-April
- Graphics Utilities - updated for Nordic support by end of March
  - CLPanel, WinPanel, OEMSI

Cirrus Confidential  
Business Information

CL 158883

For Internal Use Only



# Nordic Software Support

- Panel Type Support Priority for BIOS
  - 9-bit TFT, 640 x 480
  - 8-bit Dual Scan Monochrome STN
  - 16-bit Dual Scan Color STN
- Graphics Application Driver Support -
  - Drivers for all Windows versions (Chicago, NT, J-Windows)
  - Lotus 3.0 drivers
  - OS/2 2.1 256 and 64K color drivers
- Multimedia Drivers and Utilities
  - CD4215 Audio Codec to WavePort drivers & utilities supported first
    - Analog Devices 1849 expected to be drop in alternative
  - Playback drivers for Cinepak & Indeo
  - VidCap for FC and Compressed Video designs
  - Possible license fee for distribution rights

**For Internal Use Only**



DIGITAL CHIPS

# Portable Multimedia System



Cirrus Confidential  
Business Information

CL 158885

For Internal Use Only

© 1993 Cirrus Logic Inc.

# Live Video through the Host Bus Compressed Video Data via PCMCIA



Cirrus Confidential  
Business Information

CL 158886

For Internal Use Only



Internal Use Only

Cirrus Logic Portable Multimedia Presentation - December, 1993

Internal Use Only

# Nordic Live Video Solutions

## Video over Host Bus

- **Video over the host bus solution could be an optimum solution for live video on a portable**
  - Provide up to 24-bit quality, 640 x 480, 30fps motion video
- **Could use PCMCIA slot to provide multimedia capability**
  - industry standard connector
- **Cost of Video solution is external to the basic system**
  - System can be sold at competitive cost but is also multimedia capable
- **Added margin potential through live video add-on modules sales**

**For Internal Use Only**



# Nordic Live Video Solutions

## Video Overlay Port - Issues

- **Most likely a docking station design**
  - Unlikely to embed necessary video components onto planer
  - May also be reluctance to define a dedicated connector for FC on the chassis
- **Limited to video overlay**
  - Frame capture difficult in terms of architecture, cost
- **Bandwidth limited** - 15 frames per second overlay
- **Functional tradeoffs In 208 pin package**
  - Power management and panel support are effected if FC is used for video overlay



DATE 07/12/95

# Nordic Video Overlay Port

## Live Video to Display via Feature Connector Pins



Cirrus Confidential  
Business Information

CL 15889

For Internal Use Only

# Nordic Live Video Solutions

## Video Overlay Port

- Feature Connector pin interface to provide a video overlay port for live Video input
  - Utilizes Cirrus Logic Media Manager add-in board as reference to speed design, software, and driver development
  - Offers a customer the fastest design path to provide live video capability on a portable
    - Add-on TV Tuner module using FC interface
    - Capable of handling up to 640 x 480 / 16bpp video data
- FC can look like VAGC using external mux to provide 16-bit data

For Internal Use Only



# Merging Portable & Live Video

## Current Implementation

Video Decoder  
Scalar, TV Tuner  
Frame Buffer Memory  
Custom Connectors

## Issues



Power Consumption  
Cost  
Space - only add-in card

## Notebook Restrictions

|                |                            |                       |
|----------------|----------------------------|-----------------------|
| Physical space | 3.3V operation             | Keep cost             |
|                | Power Down when not in use | external to base unit |

CL 158891

# For Internal Use Only



# Video Playback Window

- Video Playback - a key use of multimedia on a portable
  - Currently GUI environment and Video playback window must run at same color depth (typically 8bpp)
    - Tradeoff Video quality to maintain acceptable GUI performance
    - Higher pixel depth to improve video quality means larger display memory requirements, decrease in GUI performance
  - Nordic MVA - allow a 24bpp Video playback window while running 4- or 8bpp Windows
    - Requires less display memory while improving video clip quality without degrading Windows GUI performance
    - Will support multiple types of data for playback enhancement (including Cinepak and Indeo formats)
    - Simplifies use of multimedia video for end user



DOITETT CLASSICS

# Video Playback Acceleration



**For Internal Use Only**

Cirrus Confidential  
Business Information

CL 158893

*Cirrus Logic Portable Multimedia Presentation - December, 1993*

*Internal Use Only*

**CIRRUS LOGIC**

# Digital Audio Integration Issues

- **Audio Input threshold level detect**
  - Enables Audio input capture only when threshold is reached
  - May be very attractive feature for voice recognition software
- **Soundblaster register compatibility can be provided with additional IC's**
  - Media Vision, OPTi (Media Chips acquisition) have soundblaster IC's
  - Cirrus will try to provide reference design application notes

Cirrus Confidential  
Business Information

For Internal Use Only

CL 158894



# Digital Audio Support

- Direct interface to CS42xx Audio Codec
  - 6-wire serial data interface should also be able to support Analog Devices AD1849 codec
- Full duplex audio
  - Maintains two circular audio buffers in video memory
    - Set up as two 32K audio data buffers (In/Out) fixed at high memory address (right under H/W cursor)
- Support up to 16-bit (CD-quality) audio data
  - Mono or stereo up to 44kHz sampling rate
- Pins provided to support power down and mixed voltage (digital logic areas) capabilities of Crystal codecs

Cirrus Confidential  
Business Information

CL 158895



**For Internal Use Only**



**CIRRUS LOGIC**

# Waveport™ Digital Audio Support



**For Internal Use Only**



**CIRRUS LOGIC**

# Nordic Product Features

## Multimedia Overview

- **Waveport™ Audio Port**
  - Provides Audio data buffer without using system resources
  - Provides a glueless 32-bit local bus interface to the audio codec
- **Motion Video Architecture for Playback**
  - Enhanced quality and performance with multiple video data types (different types of compressed video data)
- **Live Video**
  - Provide a standard live Video input method (Feature connector)
  - Continued development of video over the Host bus solution

**For Internal Use Only**



## Nordic Product Features

### Hardware Pop-up Icon

- Up to 4 64x64 Icons displayed as a vertical bar
  - All icons move together and can be positioned anywhere
- Each icon has independent display control for
  - icon number i enable for display ( $i = 0 : 3$ )
  - display mode : 3 color + transparency or 4 color
  - blink enable at text cursor rate or half rate
  - horizontal pixel doubling ( extends to right)
  - vertical scan line doubling ( extends down)
- H/W Cursor goes on top of H/W Icon
- Eight 64x64 icon maps are supported : two per icon

For Internal Use Only



# Nordic Product Features

## NTSC Out

- NTSC-Out

- Used to display digital graphics data on a TV monitor
- Nordic to output locked interlaced RGB data, dot clock, and sync for digital and even analog NTSC/PAL encoders
- 24-bit RGB on standard designs, 18-bit RGB when Feature Connector option is used
- NTSC-Out pin functions are shared with panel pins



For Internal Use Only



## Nordic Product Features

### External Monitor Support

- 24-bit DAC
  - 8-bit/256 color, 15-bit/32K color (Targa), 16-bit/64K color (XGA), and 24-bit (true color) modes supported
- Resolution Support
  - CRT Clock support = 65MHz at 3V, 85MHz at 5V
    - 3V = non-interlaced resolution up to 1024 x 768 @ 60Hz
    - 5V = non-interlaced resolution up to 1024 x 768 @ 75Hz

Cirrus Confidential  
Business Information

CL 158900

For Internal Use Only



CIRRUS LOGIC

# Nordic Product Features

## Panel

- New panel type support vital to system differentiation
  - Anticipating 640 x 480 18- & 24-bit TFT panels to be major factor
  - New high resolution panels- 800x 600 TFT (9-bit to 18-bit)
    - Viewed as a major differentiation for market leaders
  - Dual Scan Color STN support for value-priced color market
  - Support for up to 800 x 600 dual scan color with SimulSCAN
  - Monochrome dual scan STN support for economical system
    - Grey shading targeted to work with 100ms response time
- HW Expansion & Centering with Super VGA resolutions
  - Automatic H/V centering if expansion is not active
  - Different expansion methods required for Text and Graphics
    - 10-dot wide font support also planned

**For Internal Use Only**

# Nordic Product Features Performance

- **1MB or 2MB scalable memory**
  - 32-bit interface to display memory
  - Support for 256K x 16-bit (symmetric & asymmetric) or 512K x 8-bit DRAM (symmetric, for 2MB, 32-bit wide only)
  - Memory Clock support = 40MHz at 3V, 50MHz at 5V
  - Pins pre-defined for future synchronous DRAM support
    - Cirrus will provide Applications note to describe a Nordic 1a design that is upgradable to synchronous DRAM
- **Power Management**
  - Mixed 3.3V/5V operation, Standby, Suspend, and DPMIS supported
- **48K VGA BIOS decode to provide full feature set**
  - Modular 32K BIOS also possible
    - Customer uses OEMSI to delete unused or unneeded sections of BIOS (panel types, fonts, etc.)

**For Internal Use Only**

# Nordic Product Features

## Performance

- Minimum 25 Million Winmarks at 640 x 480 / 256 colors
  - Current GD5428 = 25million Winmarks (ver. 3.11)
    - 640 x 480 / 256 colors, 50MHz MCLK, 66MHz DX2 local bus
- GD5428 core performance features
  - 32-bit BitBLT with Memory Mapped I/O
  - Hardware Cursor = 32 x 32 or 64 x 64 pixel size
  - Color Expansion = 8bpp & 16bpp
  - Linear Addressing
  - CPU write buffer (16 x 32)
- 32-bit Local Bus runs 33MHz @ 3V & 5V
- 32-bit PCI bus @ 33MHz by specification

Cirrus Confidential  
Business Information

CL 158903

For Internal Use Only



Internal Use Only

# Nordic Accelerated VGA/LCD



Cirrus Confidential  
Business Information

CL 158904

- Based on GD5428 Desktop VGA Core
- Windows Acceleration: 32-bit BitBLT
- 1-2 MByte Scalable Video Memory
- 32-bit VESA VL or PCI Local Bus Interface
- For Internal Use Only**
- Up to 1024 x 768 NI, 256 color @ 75Hz on CRT
- 800 x 600 TFT and STN panel support
- SimulSCAN (including Dual-Scan Color STN)
- Live Video /Video Playback Enhancement
- Audio Port to Display Memory

3.11 Winmarks  
in Millions  
(640 x 480, 8-bit)

# 1994 Product Roadmap

## Market Segment

Matterhorn

High end, performance  
driven, DRAM -based.

Cirrus Confidential  
Business Information

CL 158905

Viking

Upper mid-range notebooks  
with a blend of performance  
and multimedia. For users that  
use notebooks as their primary  
system.

Nautilus

Mid-range, value-line  
to sub-notebooks. Primarily  
desktop users who want a  
portable for a second system.



5428 BitBLT  
1-2MB Display RAM  
800 x 600 LCD's  
Motion Video Arch.  
WavePort  
Video Overlay  
208 QFP C-8



32-bit Bus  
512KB DRAM  
Dual Scan Color STN  
SimulSCAN  
176VQFP

For Internal Use Only

1995  
Q1

# Portable Product Strategy

- Develop a family of products that covers the expected major market segments
- Shrink the time and performance delta between portable graphics and desktop
- Leverage desktop technologies and market success
- Accelerate multimedia capability on portables

**For Internal Use Only**





## MEMORANDUM

December 20, 1993

To: John Carlisle  
cc: Bob Conner  
Prem Talreja  
Mike Callahan  
From: Del Mank  
Subj: IBM Power Personal Systems

Attached is the presentation material used during our meeting on December 16, 1993 with IBM Power Personal Systems. The Woodstock information is all covered under NDA and is designated as NDA material on the attached copies.

Please forward to the appropriate IBM personnel as part of our follow-up.

Thanks,

A handwritten signature in black ink, appearing to read "Del Mank".

Del Mank

attachment

1/6/94

RCV BY:CIRRUS LOGIC OPS

: 1- 5-94 : 8:21PM :

813334C9120- CIRRUS LOGIC OPS:8 1

IBM



EXHIBIT

RX-552

C

FACSIMILE COVER SHEET

Date: 1/6/94

Attention: Bob Dickinson

Company Info.: \_\_\_\_\_

Facsimile No.: 510-226-2250

From: JOHN NIZUMA

Re: I

Comments: \_\_\_\_\_

Attachment(s):

• Nittoh-Son's letter

• Latest IBM's questions.

CC: \_\_\_\_\_

Number of Pages (Including Cover Letter) 5

Shinjuku Green Tower Bldg. 26F  
6-14-1 Nishi-shinjuku, Shinjuku-ku, Tokyo 160  
Telephone 813-3340-9111, Fax 813-3340-9120

Cirrus Confidential  
Business Information

CL 159497

RCV BY:CIRRUS LOGIC OPS : 1- 5-94 : 8:21PM : 813334C8120= CIRRUS LOGIC QFS:8 2

To: FAX --IBMMAIL  
cc: JL18828 --VMTVM4 Kegawa, Satoshi NAKAZA --VMTVM4 Nakazawa, Yukifumi  
Subject: Uncl: Nordic  
Sensitivity: ----- Unclassified -----  
From: Arimasa Naitoh, 81(Japan)-482-73-8110 or 2472

Mr. Dickinson,

Thank you very much for your presentation of your video chip Nordic and also road map of your future video implementations. Although I have not fully understood your future plan on multi-media support yet, I am sure that I am interested in your Nordic for our 9/94 product.

We have carefully reviewed the specifications and availabilities of Nordic, and I have the following requests for me to consider the Nordic chip in our product in more serious manner.

1. Price Information

Please provide Price information in the yearly quantity of 50K - 100K range.

2. Availability of samples - to be improved

We would need the sample of our engineering test (qty 20 to 30) by mid March and the sample for System Integration Verification Test (qty 200 - 300 ceramic package) by Mid April.. If it is possible to get the first working samples by Mid March, schedule wise we could implement Nordic in our 9/94 products even it is very critical.

3. Performance

Main reason why I am interested in the Nordic is high performance. As I made the question on the meeting, it is not yet 100% clear to me why you can assure same performance as your desktop chip since I still believe that VRAM(DRAM) is shared with frame buffer function to drive LCD, and that there might be some performance degradation. If you provide me any more information to make me more comfortable on the performance you are claiming, it would be appreciated.

4. Early Evaluation Board

If we decide to pick up the Nordic, then we would need to make our BIOS ready to test by the time we get your first samples. Please make necessary arrangement to provide us your current chip, which we were told register compatible to the Nordic, as soon as possible. And also we would like request you to provide us the source code of the BIOS for the current chip for our reference.

5. I/O decode

Due to the shortage of I/O pins, the Nordic needs external circuit to decode the I/O address, which could be a reason why we could not use the Nordic. Would you please reconsider the design so that we do not need the external circuit .... Instead we would have no

Cirrus Confidential  
Business Information

CL 159498

FCV BY:CIRRUS LOGIC OPS : 1- 5-94 : 8:22PM : 81333400120# CIRRUS LOGIC OPS:z 3

problem if you remove your audio features from Nordic.

This note doesn't immediately means we are going to use the Nordic, I need your strong support for us to make the assessment. One of my engineers S. Kegawa sent the list of question to Mr. Niijima. Your personal attention to get us the answers in timely manner would be also appreciated very much.

Sincerely

Arimasa Maitoh

Regards,  
Maitoh  
Fax 81(Japan)-462-74-4942

© 000054131 "003400

Cirrus Confidential  
Business Information

CL 159499

# CIRRUS LOGIC K.K.

Shinjuku Green Tower Bldg. 26F  
5-14-1 Nishi-shinjuku, Shinjuku-ku, Tokyo 160  
FAX: 81-3-3340-9120  
TEL: 81-3-3340-9140

## FACSIMILE MESSAGE

Date: 1/5/1994

Ref#: JN9401-X/5

To: Dennis Jow - Cirrus Logic Inc.

From: John Nijima - CLKK

Total Pages: 2

Cc: T. Wada / Bill Knapp / Y. Sasaki - CLKK  
Ralph Barne / K. Fujii / Joe Dews - CLKK  
Prem Tareja / Robin Han - Cirrus Logic Inc.  
Bob Conner / Bob Dickinson - Cirrus Logic Inc.

Re: Nordic Questions - IBM Yamato

Dennis,

Kagawa-san sent me additional questions on Nordic. I've prepared my answers for some of them (written with under line). Please review those questions and my answers. If you find any error, please correct it.

- 1) For STN color panels, Nordic can generate 4096 colors for text and 256K for graphics when "16 frame x 4 dithering" is selected (page 9-101). Why are number of colors are different between text and graphics? (Nordic will not use dithering for text mode)
- 2) Can Nordic display 256K colors on 18bpp TFT panel (640x480) in true color mode? (Yes)  
Will you provide display driver for that mode (640x480x24bpp)? (Yes)
- 3) IBM will make the display unit to be upgradable from color 16 bit DSTN panel to 18bpp TFT panel. They want to minimize number of signals run into the display unit. If all of 16 bit interface signals for DSTN panel are subset of 18 bit RGB signals for 18bpp TFT panel, that's good. IBM wants to know connection lists for 16 bit DSTN panel and 18bpp TFT panel.
- 4) IBM will use local bus (VESA or 486 direct) configuration. Is there VGA disable port w/ address 3C3h? What is the bit assignment? Is there any other VGA disable port?
- 5) Nordic will not have full 32-bit address bus input in the local bus configuration. What kind of address decoder will be needed on HIGH MEMORY input?  
(This is same issue which Naoto-san asked to Bob Dickinson in his 12/29/93 letter. IBM doesn't want to put external decode logic. It may cause critical timing path and need additional board space)
- 6) When will Nordic evaluation board be available? What will be the price?
- 7) Can Nordic output video data stream for PAL encoder such as SAA7199B? IBM needs to

Cirrus Confidential  
Business Information

CL 159500

RCV BY:CIRRUS LOGIC QPS

: 1- 5-94 : 8:23PM :

813334C912C- CIRRUS LOGIC QPS:8.5

build an European model.

- 8) Does GD6235 have similar register set (excluding BiBLT engine) to Nordic? What is the availability of the evaluation board (VL bus)?  
(This is also mentioned in Naroh-san's letter)
- 9) When 50MHz MCLK is used, Tpc will be 40ns. Generally, 70ns DRAM requires 45ns Tpc. Does it mean that 60ns DRAM may be necessary when 50MHz MCLK is used?
- 10) IBM will use the VGA controller at 3.3V. Nordic will support 65MHz VCLK at 3.3V. What is maximum frequency of MCLK at 3.3V? Is it 40MHz? It may not be acceptable for IBM. It is significantly slower than 50MHz MCLK for 5V operation. 44-45MHz is in the acceptable range. Can we guarantee 44-45MHz MCLK operation at 3.3V on Nordic?

Best Regards,  
John.

CONFIDENTIAL - CIRRUS LOGIC

Cirrus Confidential  
Business Information

CL 159501

1/7/94

\*\*\*\*\*  
\* User name: SHAW (11) Queue: UIDESK/UNIX\_JIMKG7  
\* File name: Server: CLFPCD01C  
\* Directory:  
\* Description: TOSHIBAO.  
\* December 21, 1998 6:04pm  
\*\*\*\*\*

EXHIBIT

RX-561

C

\* SSS H H A W W  
\* S S H H A A W W  
\* S H H A A W W  
\* SSS HHHHH A A W W W  
\* S H H A A W W W  
\* S S H H A A W W W  
\* SSS H H A A W W

\* L SSS TTTTT  
\* L S S T  
\* L S T ::  
\* L SSS T ::  
\* L S T ::  
\* L S S T ::  
\* LLLL SSS T ::  
\*\*\*\*\*

00005431 303400

Cirrus Confidential  
Business Information

CL 153203

## Memo

**TO:** John Niijima - CLKK  
**FROM:** Vlad Bril - Cirrus Logic Inc.  
**DATE:** January 7, 1994  
**RE:** Questions on Nordic  
**CC:** Dennis Jow, Bob Conner, Bob Dickinson, R. Han, Del Mank, T. Wada, T. Ho

Thank you for making inquiries about Nordic.

Lately I got two faxes with questions on Nordic functionality. This fax will answer most of the questions.

I'll be glad to be of further assistance if necessary.

I'll start with the fax with the ref. # JN9401-010 of 01/06/94:

**Q1:** Status of every signal during suspend.

**A1:** Nordic can go into Suspend Mode:

- by pulling H the Suspend Input Pin (SUSPI) -> h/w suspend
  - by asserting a register bit (CR20[3]) -> s/w suspend

Minimum power consumption is achieved with h/w suspend.

By definition, Suspend is a minimum power state in which the system is not accessing the graphics controller or the Video Memory.

If it is desired to put Nordic in a state in which CPU executes programs while reducing power consumption, Nordic should be in Stand-by mode.

a. In suspend most input buffers are disabled so that even if the input is floating, toggling or in-between the rail they do not take any power. Exceptions are: the Reset pin, the Suspend Input Pin, 32KHz input.

- H/W Suspend minimizes power consumption on the CPU bus side on all pins.
  - S/W suspend leaves some pins active on the CPU side so that an 8bit I/O could get the chip out of the s/w suspend state.

The way the CPU bus pins are treated is the only difference between s/w and h/w suspend.

b. In both s/w and h/w suspend most output buffers are forced L so that they do not feed a non powered device, like the flat-panel.

- All outputs to the Flat Panel are forced L in Suspend.
  - We assume the Video Memory DRAM-s powered on and refreshed. Either slow refresh (at 8KHz) or self-refresh can be used. RASn, CASn which are toggling at 8KHz frequency if slow refresh is selected, as well as VEn and QEn which are held at

Memory Data pins MD[31:0] are configured as inputs and the inputs are forced H internally, so that Nordic does not take power.

Please note that the external configuration Pull-Ups on MD[] pins will not take power in Suspend as the MD signals are floating in Suspend. Nordic MD[] inputs are internally forced H in suspend so that the floating state of the MD[] signals does not lead to power consumption. Even if we decide to drive MD[] signals H in suspend, these Pull-Up-s will

MEMO

not take power. The internal pull-downs on the MD[] pins are active only at reset or s/w switch read. So they do not take power.

- Feature Connector Data I/O-s FCP[7:0] are also configured as inputs and the inputs are forced H internally. We assume that the h/w driving the Feature Connector is not powered during suspend.

- FCVCLK input is forced H internally.

- All Feature Connector control inputs like, FCESYNCn, FCEVIDEOn are forced internally to the state for FCP[7:0] = input to Nordic.

- FCBLANKn, FCDCLK, OVRW outputs are forced L.

- If the Feature Connector is not enabled, all FC pins shared with 24bit panel pins will stay outputs, driven L in Suspend.

- TV-Out outputs (CSYNC = Composite Sync, NTSC/PAL and TVON) will be driven L during suspend. These pins were added recently to support Analog TV Encoders like AD720 and MC1377.

- HSYNC and VSYNC signals are controlled by pre-programmed GPMS register bits. This way the CRT Monitor could be in either Stand-by or Suspend. We drive 32KHz on them or drive them L depending on GPMS register bits value. GPMS is the "Green PC" specification for CRT Monitors which Nordic supports.

- R,G,B are blanked in suspend and the DAC as well as the RAMDAC RAM are in power down mode.

- Panel Power Management pins are inactive (L) in Suspend.

- OSC (the 14MHZ clock ) input is also internally forced H in Suspend.  
Both dot-clock and memory-clock synthesizers are stopped.

- In H/W Suspend CPU Address, Byte Enable and Command inputs are all internally disabled (H). CPU Data DAT[31:0] are inputs and forced H internally. The CPU bus may be floating as far as Nordic is concerned - Nordic will not take power because of a floating CPU bus when in h/w Suspend. The CPU bus Outputs RDYn, LDEVn, INTR will be inactive (RDYn =H, LDEVn=H, INTR=H if Interrupt is cleared in register CR11).

- In S/W Suspend CPU DAT[7:0] is active, as well as all addresses and bus command inputs. This allows to execute 8bit I/O commands to get the chip out of the Suspend state. This is the main reason S/W Suspend takes more power than H/W Suspend.

If the CPU Bus activity is stopped or low intensity and the voltage levels on the CPU Bus are CMOS levels (close to the rails -VDD or GND), S/W suspend power consumption will be close to h/w suspend power consumption.

Please note that Nordic actually **drives low** all outputs going to powered down devices. when in Suspend.

**Cirrus Logic Question:** What is the status of the CPU Bus during suspend? Active, floating, quiescent (no activity) ?

**Q2: Estimation of Suspend Current.**

**A2: H/W Suspend Current** is estimated, in production stage to be:

- below 250uA at 3.3V Core-VDD, with 32KHz clock.
- below 1mA at 5.0V Core-VDD, with 32KHz clock.

**S/W Suspend Current** is estimated, in production stage to be:

- below 350uA at 3.3V Core-VDD if the CPU bus is fully quiescent and the DC levels of the CPU bus signals are within 0.2V off the rail (CVDD or GND).
- below 1.2mA at 5.0V Core-VDD if the CPU bus is fully quiescent and the DC levels of the CPU bus signals are within 0.2V off the rail (CVDD or GND).
- below 2mA at 3.3V Core-VDD if normal CPU bus activity in the system
- below 4mA at 5.0V Core-VDD if normal CPU bus activity in the system

It is highly advisable to have 3.3V, or even 3.0V Core-VDD at the time Nordic is in Suspend Mode. This will minimize Suspend Power Consumption. The peripheral VDD-s (CPU bus, panel, CRT&TV, memory) may remain 5V.

The Suspend-Status Output (SUSPSTn) can be used by the system to know when the chip is in actual Suspend State.

Please note that DACVDD-s and Clock Synthesizer VDD-s should have the same value as the Core-VDD, at all times.

**Q3: Support for self refresh and slow refresh DRAM-s.**

**A3:** As in CL-GD6205/15/25/35 controllers, Nordic will support both self and slow refresh DRAM-s. The basic frequency of 32KHz can be derived from a 32KHz clock (RTC) or internally (on chip) by dividing the 14MHz signal supplied on OSC. If external 32KHz signal is not supplied to the chip, the suspend power will be higher (by 300uA at 3.3V Core VDD). For slow refresh DRAM-s 8KHz refresh frequency is used.

**Q4: Power Sequencing during transition between normal, standby and suspend modes.**

**A4:** I do not quite understand what you mean. Nordic assumes that all VDD-s to the chip remain ON in all modes of operation.

If one VDD is OFF, all VDD-s should be OFF. In no mode Nordic saves power by cutting one or more VDD-s off the chip.

Nordic executes by itself power sequencing to the Flat Panel when going into Suspend and Stand-by. Nordic also has an option to control only the Back-light of the panel for quick power reduction.

Stand-by is a timer driven mode (if no Video Memory Access happened within a programmed time the chip goes automatically into Stand-by) but it can be also s/w or external input pin driven.

It is not clear to me what you mean by "power sequencing" that leads you in and out of suspend. Do you mean I/O register write sequence?

MEMO

I'll continue answering the fax with ref # JN9401-015:

**Q1: Handling of Color Palette Index Register/RGB Temporary Latches/Attribute Controller Toggle Flip-Flop and 32bit Graphics Controller Data Latches.**

I see several related questions:

1. Can Nordic save all this data in normal operation?
2. Can Nordic read and write all this data during stand-by?
3. Can Nordic read and write all this data during suspend?
4. Can Nordic read and write all this data during suspend resume sequence?

Answers:

1. As it is now, in normal operation, Nordic:
  - can read and write the Color Palette Index Register ARX: read at CR26, write at 3C0 with Attribute Toggle = 0. I assume you mean the 16 stage EGA/VGA internal palette (not the RAMDAC 266 stage palette)
  - cannot read RGB Temporary Latches in the RAMDAC RAM. Our BIOS has a mechanism to handle this limitation in its Save/Restore routines. I asked the BIOS engineer to explain in detail how it is done. If what we do now will prove not to be sufficient, we could look into making these Shift Register Latches readable. I assume you are talking about the 6bit x 3 Shifter used by the RAMDAC RAM to accumulate RGB via I/O before writing all 18bit of data into the RAM.
  - can read Attribute Controller Toggle Flip Flop at CR24 and write it by resetting it and then do a dummy attribute index write.
  - can read the 32bit Graphics Controller Data Latches at CR22 with GR4[1:0] selecting the byte to be read. To write these Latches though one needs to write the read in memory and then do a memory read.

2. Even if dot-clock is stopped in stand-by, Nordic detects a CPU access to the RAMDAC registers and temporarily uses OSC clock to execute the access. So, there is no difference in the operation from the CPU side when the chip is in stand-by versus normal operation.

3. A. In S/W Suspend, we can access all registers but RAMDAC and Attribute Palette (which require dot-clock to be accessed). Even if mclk is stopped, doing I/O does not require mclk (only bus clock).

B. In H/W Suspend, we cannot access any I/O register as the CPU inputs are forced to make them insensitive to CPU bus activity.

4. During suspend resume sequence (when Nordic goes out of Suspend), as long as the CPU bus inputs are not forced internally, it is possible to execute most I/O-s. The I/O-s that require dot-clock should be executed only after dot-clock synthesizer is on.

To facilitate the restore operation after suspend, Nordic has two status bits:

- suspend status bit, that can be polled waiting for the internal suspend terminate sequence to complete

**MEMO**

---

- power sequencing on status bit that can be polled to know when the internally generated and controlled power sequencing to the Flat Panel power supplies, is completed.

This provides for a simple mechanism of waiting to start restoring the state after suspend and to know when it is OK to assume that the Flat Panel Display is on. Please note that when the chip goes out of Suspend state, towards the end, Panel Power Sequencing takes place if the chip was in panel.

Now, let me go to the main issue:

I think that there is a misunderstanding between us and Toshiba. I fully understand why a good save/restore mechanism is needed. I understand that in a password system a mode change may happen before actually restoring the data as it was before suspend.

Where I think that we mis-communicate is when we are told that Toshiba needs to do the actual save/restore operation "while in SUSPEND MODE".

In our model of thinking,

- the state should be saved first,
- then the Suspend pin should be asserted, starting the internal process of putting the chip in suspend,
- while the chip is in Suspend Mode no CPU access to the chip should happen.
- the first thing to do when going out of suspend is to de-assert the suspend pin and start polling the Suspend Status Pin or the Suspend Status bit until the internal sequence of getting out of suspend is completed. If it is desired to change the mode before starting the display, than the LCD enable register bit can be disabled before going in Suspend. In this case the Flat Panel will not be power sequenced after coming out of Suspend.
- now s/w starts accessing Nordic and programs the graphics mode and Video Memory for password display.
- After the password is given by the user, the original Nordic state is restored.

I do not understand why at any moment there is a need to actually access the chip while it is in Suspend Mode. Save state should be done before the chip goes into suspend. Restore state should be done after the chip goes out of Suspend state. The Suspend pin should be controlled by the CPU through an Output port and not by the lid switch. The lid switch that triggers the Suspend sequence should interrupt the CPU and should get the CPU to the Restore operation.

Please note that Save and Restore are Video BIOS calls.

**We need to close this issue ASAP. If it turns out that we actually need to access the chip while in Suspend Mode, the suspend current will be higher than what we can get otherwise.**

**Cirrus Confidential  
Business Information**

**Q3: PAL Output Support With Analog Encoder for IBM**

a. We are planning to support AD720 and MC1377. I heard about a part AD722 but I do not have a data sheet yet. We can support any part that requires Composite Sync, a selection of NTSC/PAL and a Power Down pin.

b. AD720 is 28lead PLCC (P-28A with a print of 12.45mm)

MC1377DW is 20 lead case 751D (SO-20L looks like a small surface mounted DIP, but I do not have package size yet). A plastic DIP is also available.

c. Nordic will use CRT analog RGB outputs to support the encoders.

d. We'll present an application note on how TV-OUT option. We will not require external switches.

It is important to remember that the CRT monitor has 75 Ohm resistor at the RGB input. The DAC output has 150 Ohm resistor close to it. Together in DC they make a 50 Ohm resistor. With this load the DAC delivers 0.7V full swing for a 6.6mAmp IRef.

If the CRT Monitor is not connected, the load is 150 Ohm and the full swing DAC output voltage is 2.1V for the same IRef. AD720 required input voltage is 0.7V while MC1377 is 1.0V.

There are three ways to connect the video encoders and the CRT. We are now in the process of deciding which one is the best:

1. The simplest way to connect the TV decoder is to assume that the CRT Monitor should not be hooked to the notebook computer at the time the TV is. In this case we can put a high resistance voltage divider (2KOhm) to get the required 0.7V or 1.0V full swing to the decoder. The 2KOhm voltage divider will not practically affect the 50 Ohm resistance on the CRT, when the CRT is hooked on. The disadvantage of this method is that it requires a CRT to be disconnected from the note-book computer when connecting a TV. The TV encoders get RGB input through an AC connection (a capacitor) so the DC source may be a high resistance.

The advantage is that it is simple and low cost.

2. There are no buffers or other resistors than usual. We control the RSET resistor value on the LM334 current source depending on the presence of the CRT Monitor hook-up or not. If the CRT Monitor is not hooked-up, we adjust IRef so that DAC-s full swing output voltage is 0.7V (or 1.0V) with a 150 Ohm load. If the CRT Monitor is detected to be hooked up, RSet will be left as it is now. The adjustment is done automatically with a transistor. This approach requires a programmable output (from Nordic or Core Logic) to control RSet value. The detection of the CRT Monitor presence is done by s/w the standard VGA way.

3. Put 50 Ohm load on the DAC output and feed it to the TV encoder and to an Analog Voltage Repeater that drives the CRT Monitor RGB lines. This way DAC output is always 0.7V full swing independent if the CRT Monitor is hooked to the notebook or not.

This approach works for AD720 but not for MC1377 which requires 1V full swing. With this approach the presence of the CRT monitor cannot be detected VGA style (incompatibility issue?).

e. Nordic does have a programmable output pin to select PAL or NTSC to the

**MEMO**

---

encoder.

It also has a programmable output pin to control TV encoder power-on (AD720).

**Q4: Additional Address Lines**

A4: Nordic has now in VESA VL bus addresses from 0 to 25. We called addresses 24 and 25, HIMEM0 and 1, because one can hook any of the upper address lines to it (for instance addresses 31 and 30).

Three possible ways to connect an Analog PAL/NTSC TV Encoder to DAC output

00000000000000000000000000000000

DRAFT - DO NOT DISTRIBUTE



**Cirrus Confidential  
Business Information**

CL 153211

1/14/94

IBM

シーラス・ロジック株式会社 〒160 東京都新宿区西新宿6-14-1 新宿グリーンタワーB26F Tel:03-3340-9111/12/13 Fax:03-3340-9126

EXHIBIT

RX-553 C



January 14, 1994

Mr. Arimasa Naitoh  
Manager of Notebook Product Development #1  
Portable Systems, PS Products  
IBM Japan Ltd.  
1623-14 Shimo-tsuruma, Yamato-shi  
Kanagawa-ken 242, Japan

Dear Naitoh-san:

I believe that there is now regular communication on Nordic technical specifications between your engineers and ours. In terms of the video roadmap, I would like to present an overview to you on January 19 followed by a detailed presentation the week of February 7.

In this letter I will focus on the specific questions you raised in your fax:

1. Pricing

Based on an annual quantity of 50-100K, we can offer the following pricing:

|               |          |
|---------------|----------|
| Q3 1994       | \$ 31.00 |
| Q4 1994       | \$ 28.00 |
| 1st Half 1995 | \$ 26.50 |
| 2nd Half 1995 | \$ 25.00 |

2. Schedule

As a result of the discussions with your engineers, we have made some changes to the Nordic design. We are now expecting to tape out the base layers by the end of February and receive first silicon in early April. Depending on how many problems we find, we will be able to provide initial samples between mid-April and early May.

Because we have removed several complex features from the design(the WavePort and video port), we remain confident, however, in our ability to provide 10-20K production units in July. We will be happy to share our schedule with you in greater detail if you wish.

3. Performance

Our performance assumption is based on measurements using the GDS428 VL-bus demonstration board. With 1MB of 70ns 5V DRAM and 50MHz MCLK, we have achieved 24-25 million WinMarks under WinBench 3.11 and 8-9 million WinMarks under Winbench 4.0 at 640 x 480 resolution, 256 colors in a 66MHz DX/2 system.

Cirrus Confidential  
Business Information

CL 159503

CIRRUSS LOGIC

While it is true that the DRAM in Nordic will also serve as a frame accelerator, the frame buffer is not required when Nordic is driving TFT or single scan STN panels. In this case, Nordic will drive the CRT and LCD panels at the same clock speed so there should be no performance difference.

The frame buffer is only utilized when a dual scan STN panel is being driven. However, our memory architecture allows the memory and CPU interface to remain 32-bit even when the frame buffer is used. As a result, the performance degradation should be less than 15%. This is substantiated by the attached performance comparison of CRT versus dual scan color STN LCD performance for one of our current controllers, the GD6440.

#### 4. Early Evaluation Board

We are planning to have a Beta version of the Nordic BIOS available with the first sample. The way we can achieve this is to check the CRT functionality of the BIOS using the desktop controller, the GD5428, on which Nordic is based. When we have the Nordic silicon, we can concentrate on testing the functions added to the desktop base including LCD panel interface, power management and PCI interface.

Using a simular procedure, IBM can first review the GD5428 BIOS kit and then start system BIOS development using the Nordic register information we will provide in the first week of February. The CRT functionality of the BIOS can be verified using the GD5428 demonstration board prior to receiving first samples of Nordic.

#### 5. I/O decode

Our original implementation for address decoding supported a physical address space up to maximum of 32 MB without the use of external logic. The specific pins were BE[0:3], ADR[2:23] and the HIMEM 0 pin. Since the WavePort has been removed from the design, we have added a HIMEM 1 pin for direct support of up to 64MB physical address space without external decoding logic.

I hope this information is helpful. Please let me know if you need any additional information.

With my best wishes for a successful New Year,  
Very truly yours,

*Robert V. Dickinson*

Robert V. Dickinson  
President, Cirrus Logic K.K.

CC:      Mr. Kimio Fujii  
              Mr. Del Mank  
              Mr. Junichi Niijima

Cirrus Confidential  
Business Information

CL 159504

# CL-GD6440-BC

## Performance Update

|                  | Mem Clock    | Resolution and Color  |                        |                        |                         |
|------------------|--------------|-----------------------|------------------------|------------------------|-------------------------|
|                  |              | 640 x 480<br>16 Color | 640 x 480<br>256 Color | 1024 x 768<br>16 Color | 1024 x 768<br>256 Color |
|                  |              | CRT                   | LCD                    | CRT                    | LCD                     |
| <b>GD6440-VL</b> | <b>45MHz</b> | <b>9.5</b>            | <b>8.5</b>             | <b>12.6</b>            | <b>10.9</b>             |
| <b>GD6440-VL</b> | <b>49MHz</b> | <b>9.8.</b>           | <b>9.0</b>             | <b>13.1</b>            | <b>11.8</b>             |
|                  |              |                       |                        | <b>7.2</b>             | <b>6.8</b>              |
|                  |              |                       |                        | <b>7.4</b>             | <b>7.9</b>              |

Benchmark = ZD Labs WinBench v3.11 Graphics WINMARK, 1 test run per resolution.

Platform = 486DX2-66 system with 256K external cache, 8MB RAM @ 70ns,  
VL-Bus, AMI BIOS, Windows 3.1 run in enhanced mode.

Display = All CRT modes are at 60Hz refresh rate

All LCD modes are with dual-scan color panels  
VGA Controller = GDK6440-A-DM2-2 VL BUS demo board with CL-GD6440-BC,  
80ns DRAM, and v1.00 BIOS.

Drivers = 256\_6440.drv alpha dated 11/09/93  
16\_6440.drv v1.00 dated 10/12/93  
Windows 3.1 standard VGA driver

Performance Note: 256\_6440.drv driver is currently under QA.  
11-11-1993



11/14/94

\*\*\*\*\*  
\* User name: SHAW (11) Queue: UIDESK/UNIX\_UIMKGT  
\* File name: Server: CLFPCD010  
\* Directory:  
\* Description: TOSHIBA2.  
\* December 21, 1998 6:10pm  
\*\*\*\*\*

EXHIBIT

RX-564 C

\* SSS H H A W W  
\* S S H H A A W W  
\* S H H A A W W  
\* SSS HHHHH A A W W W  
\* S H H A A W W W  
\* S S H H A A W W W  
\* SSS H H A A W W  
\* \* \* \* \*

\* L SSS TTTTT  
\* L S S T  
\* L S T ::  
\* L SSS T ::  
\* L S T ::  
\* L S S T ::  
\* LLLL SSS T ::  
\* \* \* \* \*

2003 RELEASE UNDER E.O. 14176

Cirrus Confidential  
Business Information

CL 153218

# Memo

TO: John Niijima - CLKK  
FROM: Vlad Bril - Cirrus Logic Inc. Ref# VB-NORDIC-J003  
DATE: January 14, 1994  
RE: Questions on Nordic #3  
CC: Dennis Jow, Bob Conner, Bob Dickinson, R. Han, Del Mank, T. Wada, T. Ho

Thank you for your fast answers.

Comments and Answers to your fax JN9401-031 2 pages.

1. So the SLEEPIn pin issue is closed. Either the selected s/w port or the sleep pin will put the chip to sleep.

2. Reset Pin Polarity. In your comment you imply that RESETn will be floating during Suspend unless I pull it up somehow. This answers one of my questions on what happens to the RESETn pin when the system goes in suspend: it is floating.

If this is the case, I can disable the RESETn pin as I do most other CPU Inputs (you remember the NOR input buffer I explained in last fax). This will force my internal RESETn H. In this case, you have to go out of suspend before trying a warm boot of the system. Is this OK?

Could you send me a list of all the signals that are floating during suspend on the CPU bus that goes to Nordic?

What happens to 32KHz pin is it floating too?

What about TRWn pin or OSC pin, or even SUSPEND Input pin itself. This pin puts the chip in Suspend... it should not float!

3. Access to RAMDAC temporary latches:

I understand now how our BIOS save/restore routine solves this problem without the use of special registers for temporary latches. If needed I can explain you and Toshiba. This code works.

Let's assume that the suspend request came after writing R but before writing G and B to the RAMDAC.

- the Save routine executes one write to the RAMDAC with some dummy data and reads the RAMDAC write index to see if it changed. It will not.

- the Save routine executes another write to the RAMDAC with some dummy data and reads the RAMDAC write index to see if the index changed. Now it will. Also the RAMDAC will be updated with the data "R dummy dummy" as RGB in the location the program was writing when interrupted.

- The Save routine saves the fact that it took two writes to change the index. This means that the program was stopped while writing R, so the Restore routine will use this data to restore only the R and then let the application continue. This way the dummy data written.

DRAFT - 2/10/94

MEMO

even if saved by the save routine, will not be written in memory at restore operation because the restore operation will stop after writing R.

- now the RAMDAC write index is saved as well as the RAMDAC contents from zero to the index.

- the restore operation will rewrite the RAMDAC till index minus one and the R for the next index.

- then it will stop and let the application continue.

Practically all Toshiba needs to do is use Cirrus Logic's Save/Restore routine or something similar.

4. RDYn and LDEVn will be floating during Suspend if the power to the external pull-ups is turned off (they will not be L, unless you ask me to pull them low). The current design is pulling them L only if there is a valid cycle to Nordic. Otherwise they are not driven by the chip, but they are driven H by an external pull-up.

5. I need data on Mode 74H ASAP.

6. I talked to my Flat Panel Expert and he was surprised that Toshiba is asking for FRM of 9bit TFT panels. I understand that 90C24 is doing this. If Toshiba requests us to do it, we'd like to work together with them on it. We'd need a panel data sheet and an actual panel they are using to do a bread-board and see what quality of shades we get. What is the speed of the panel they are using? Could you please get a demo and see what quality of shades they get now? With a very fast panel shading with FRM is usually a problem.

At present we do not have FRM for 3bit panels. Is it possible that Toshiba is doing now FRM only on the Least Significant Bit of the 3 bits/gun? How do they get this 185.193 colors number?

At present we use dither to get as many colors as the input signal can provide on a CRT Monitor. This way we can display 24bit and 16bit per pixel.

The trend we see with TFT panel development is that they go towards 6bit per gun. Are you aware of the Peanuts program? Does Toshiba intend to stay with a 9 bit TFT panel? They do not go to 12 and 18bit TFT panels? My understanding is that Peanuts is relatively low cost.

In any case, we'd like to work together to meet Toshiba's demands.

DRAFT COPY - DO NOT DISTRIBUTE

1/18/94

\*\*\*\*\*  
\* User name: SHAW (11) Queue: UIDESK/UNIX\_UIMKGT  
\* File name: Server: CLFPCD010  
\* Directory:  
\* Description: IBMJ\_QUE.  
\* December 21, 1998 6:16pm  
\*\*\*\*\*

EXHIBIT

RX-565 C

\* SSS H H A W W  
\* S S H H A A W W  
\* S H H A A W W  
\* SSS HHHHH A A W W W  
\* S H H A A W W W  
\* S S H H A A W W W  
\* SSS H H A A W W  
\*  
\*

L SSS TTTT  
L S S T  
L S T ::  
L SSS T ::  
L S T ::  
L S S T ::  
LLLLL SSS T ::

30005431-1023100

Cirrus Confidential  
Business Information

CL 153253

# Memo

TO: John Niijima - CLKK  
FROM: Vlad Bril - Cirrus Logic Inc. Ref# VB-NORDIC-J004  
DATE: January 18, 1994  
RE: Questions on Nordic #4  
CC: Dennis Jow, Bob Conner, Bob Dickinson, R. Han, Del Mank, T. Wada, T. Ho

Thank you for your fast answers.

Comments and Answers to your fax JN9401-040 1 page.

2. a. Q: What is the plan to convert from 0.8um to 0.6um?

A: Our current plan is to have 0.6um samples in Q3'94, preferably in July or August. Is there a critical time window we have to hit for IBM? If we knew when it is absolutely needed, we'd adjust our schedule as much as possible. There is a balance between improvements and features to be put in and the tape-out schedule.

In April/May if there will be some small upgrades to be made for IBM, we'd be glad to.

b. Q: Extended Data Out DRAM vendor.

A: I know Micron Semiconductor Inc. has samples of -7 and -8 parts now. Production is scheduled for -6 -7 and -8 in Q2'94. The part number is MT4C16270. It is a 2 CAS\* part. It is available in 40pin SOJ or 40pin TSOP packages.

3.3V part is scheduled to be available in Q3.

It is possible that Hitachi or Samsung are also working on such a part, but I think that Micron Semi. is far ahead in terms of schedule.

3. Q: 640x480 24bpp support at 3.3V.

A: There are several possible ways to run 640x480 24bpp. Depending on the specific way it can be run or not.

a. When Nordic runs 4:2:2 YUV, it displays 24bpp though data is stored in memory and transferred to Nordic at a 16bpp rate. In this mode, Nordic can run even at 40MHz mclk at 31.5MHz dot-clock (75H refresh), though 45MHz or 50MHz mclk would lead to much higher memory bandwidth.

This is the preferred mode for play-back under MVA. Please note that if the MVA is used and the window is smaller than 640x480, a high CPU bandwidth is obtained outside the Motion Video Window, if MS Windows is run in 8 or 4bpp.

This data is for TFT panels or CRT monitors.

b. In 24bpp RGB, Nordic can run 5428 way (at 3x the base frequency) or can run the new Nordic way, using the MVA 24bit wide data path at 1x the base frequency.

Once the appropriate driver is developed, Nordic will be able to run 640x480 24bpp RGB in 1x mode at 50MHz mclk up to about 27MHz dot-clock. With a 32bit wide DRAM, there is not enough memory bandwidth to run this mode at 31.5MHz. The refresh rate can

**MEMO**

---

be improved by reducing the non-display time on a TFT panel. The lower the dot-clock frequency, the higher the performance.

At 40MHz mclk, Nordic can run 640x480 24bpp RGB only at about 21MHz dot-clock maximum, on a TFT panel. If 3.3V core logic has to be used in this mode, the refresh rate may be improved by reducing the non-display time.

All this data is on a TFT panel or a CRT.

A recommended way to run 640x480 24bpp RGB is to run this mode at 50MHz mclk and 5V CVDD (Core VDD) and switch to 3.3V in suspend and stand-by mode. The group VDD-s (bus, memory, panel, CRT&TV) do not need to change. Analog VDD-s for RAM-DAC and Clock Synthesizers should track CVDD (they all change together).

This restriction will go away in 0.6um technology.

Best Regards,  
Vlad.

CIRRUS LOGIC, INC.

2/3/94

**EXHIBIT**RX-569 C

# Memo

**TO:** Brian Howard and Mary Johnson of Apple Computer, Inc.  
**FROM:** Vlad Bril of Cirrus Logic, Inc.  
**DATE:** 02/03/94  
**RE:** Apple's Specification - Engineering Issues - rev #2 - after getting your answers  
**CC:** Dennis Jow, Peter Pernice, Guido Carasso, Del Mank, Bob Conner

Thanks a lot for your help in understanding the issues. Following is an update of the previous data I sent you, based on the information you provided and answers to the specific questions in your fax.

Here is a summary of the meeting we had with some questions.  
I marked what Nordic can do relative to the specification you wrote on the board.  
In some cases the description is not detailed enough for me to give an answer.

Apple Spec from Brian:What Nordic supports:

PCI Bus

yes

LCD 640x480 16bpp

Yes, with the following maximum dot-clock rates:

- Sharp-Color dual scan 16bit up to 30.24MHz dot-clk
- Sharp-Mono-FSTN dual scan - up to 26MHz dot-clk
- Sharp Color-AMLCD 12bit data interface - up to 28MHz dot-clk
- Hosiden Color-AMLCD 18bit data interface - up to 40MHz dot-clk, if needed.  
Practically OK at 30.24MHz

CRT 640x480 16bpp @ 30.24MHz, 67Hz

yes

.. 832x624 8bpp @ 57.2832MHz, 68.7Hz

yes

20005471.403100

**Cirrus Confidential**  
**Business Information**

CL 157329

DOCTEST EXTRAS

MEMO

Mirror Mode 640x480x8bpp LCD & CRT

Yes, with fixed frequency or Multisync monitors with the following panels:  
- Sharp-Color dual scan 16bit up to 30.24MHz dot-clk  
- Hosiden Color-AMLCD 18bit data interface - up to 40MHz dot-clk, if needed.  
Practically OK at 30.24MHz

Only with Multisync Monitors with the following panels:  
- Sharp-Mono-FSTN dual scan - up to 26MHz dot-clk  
- Sharp Color-AMLCD 12bit data interface - up to 28MHz dot-clk.

Note: a. When running on Multisync Monitors is it possible for Apple to reduce the non-display time in order to get a higher refresh rate for a given dot-clock frequency?

Big Endian memory space for frame buffer

yes

1.4.8.16 bpp packed modes

yes

April '94 prototypes

Marketing issues.

July '94 EVD2 (production quality silicon)

Jan '95 production ramp

March '95 Intro.

Cirrus Confidential  
Business Information

CL 157330

MEMO

Brian's Wish List:

800x600 16bpp on panels

832x624 16bpp on CRT

640x480 16bpp both screens

---

What Nordic supports:

yes on TFT panels  
@ 40MHz dot-clock, 60Hz  
refresh rate.

yes on DS STN panels up to  
about 36MHz dot-clock  
(about 110Hz refresh rate or  
better, if non-display time is  
reduced). Actually we could  
run at 90Hz refresh rate at  
lower dot-clock rate to reduce  
the requirements on the panel  
spec. and get higher perfor-  
mance.

Only on a Multisync  
Monitor if the non-display  
time is reduced relative to  
the standard Apple monitors  
so that the refresh rate is at  
least 60Hz at 40MHz  
dot-clock.

Yes, with both Standard and  
Multisync Monitors at  
30.24MHz with the following  
panels:

- Sharp-Color dual scan 16bit  
up to 30.24MHz dot-clk
  - Hosiden Color-AMLCD  
18bit data interface - up to  
40MHz dot-clk, if needed.
- Practically OK at 30.24MHz

Only with Multisync  
Monitors  
with the following panels:  

- Sharp-Mono-FSTN dual  
scan - up to 26MHz dot-clk
- Sharp Color-AMLCD 12bit  
data interface - up to 28MHz  
dot-clk.

Cirrus Confidential  
Business Information

CL 157331

MEMO

800x600 16bpp LCD & 832x624 16bpp CRT

- Only with Multisync Monitors and TFT Hosiden panels at 60Hz refresh rate and 40MHz dot-clock.  
- If a fast enough Dual Scan Color Panel is available, it may be possible to run at 36MHz or 32MHz dot-clock maybe with a reduced non-display time, as even a Multisync Monitor does not need too long non-display time. Depending on how much we can reduce horizontal and vertical non-display time, we may get a higher or lower refresh rate.

2bpp packed

may deliver by July if required, not in current rev.

\$20 price @ 20-30K/mo

Marketing question.

Answers to Other Fax Questions:

1. Q: Is it an option to add an extra buffer RAM to allow Dual Scan STN Panel to run at THE SAME RATE AS CRT in mirror mode?

A: This is not a current option in Nordic.

It could be done in future products. It could actually be embeded in the standard Frame Buffer Memory. It requires twice the amount of memory band-width overhead the half frame buffer approach.

2. Q: Can Nordic drive 800x600 16bpp on Multisync Monitors?

A: Yes, up to 40MHz dot clock, with a 50MHz memory clock (to meet memory band-width requirements). We may get 60Hz or even better, depending on the horizontal frequency range of the monitor.

3. Q: Mirror for 800x600 LCD and 832x624 8bpp Apple CRT?

What about 800x600 Multisync 8bpp?

What about 800x600 Multisync and LCD 16bpp?

Are these only possible with single scan panels?

A: Nordic can display only part of the 832x624 picture on a 800x600 panel. It could

Cirrus Confidential  
Business Information

CL 157332

CONFIDENTIAL

MEMO

even pan through the larger picture. But what panel would you use at 58MHz dot-clock? Not even Hosiden runs that fast.

If we can run the CRT at 40MHz dot-clock or lower with an acceptable vertical refresh rate, we can run mirror mode as long as the panel meets the specification derived from the 40MHz dot-clock rate. Either 8 or 16bpp is OK at 40MHz, but 16bpp requires a 50MHz memory clock, while 8bpp can operate at 45MHz memory clock.

800x600 8bpp at 40MHz could be run with a Dual Scan Color or Mono LCD as long as the panel meets the specs.

800x600 16bpp can be run at 40MHz memory clock and 50MHz memory clock only with single scan panels. If either dot-clock is lower or memory-clock higher frequency by about 15%, it is possible to run this mode on an 800x600 DS Color Panel. A monochrome panel requires only about 5% extra memory bandwidth.

4. On 24bpp modes.

We need to talk face to face about your suggestions. We need a board.

I agree that 24bit/pel modes could be very useful with LCD panels using 6bit drivers. You and Bob Conner should decide in what product this will be implemented. (I can tell you how much work it is to do it.) Once this is agreed upon, we'll have the pleasure to work out the way we do it.

By the way, would it make sense to get a 4:2:2 YUV format (Y0 U Y1 V in 32bits per 2 pixels) as a graphics mode? This is a 24bpp mode that requires 16bpp average bandwidth?

64bit wide memory is certainly something you'll find in our future product line. Our strategy presentation will talk about such a product.

- - -  
Cirrus Confidential  
Business Information

CL 15733

11/21/94

EXHIBIT

RX-567 C

**CIRRUS LOGIC INTERNATIONAL LTD.**


**3100 West Warren Ave  
Fremont, CA 94538**

**FAX TRANSMITTAL****IF THERE IS ANY PROBLEM WITH THIS TRANSMITTAL, PLEASE CALL:**

**PHONE: (510) 226-2296  
FAX: (510) 226-2160**

**DATE: 01/22/94****FAX #: (408) 974-3840**

**TO: MARY JOHNSON  
BRIAN HOWARD  
COMPANY: APPLE COMPUTER INC.**

**NUMBER OF PAGES: 6  
(including this cover sheet)**

**FROM: VLAD BRIL****REF #: VB-NORDIC-AP001**

ATTACHED ARE TWO DOCUMENTS I PUT TOGETHER AFTER OUR FRIDAY MEETING. THIS WAS A GOOD MEETING. THANKS!

MARY WOULD YOU PLEASE MAKE SURE BRIAN GETS A COPY OF THIS... IF YOU DON'T MIND.

THE 1-ST DOCUMENT IN THIS FAX IS A SUMMARY (OR + COPY) OF THE SPEC. BRIAN WROTE ON THE BOARD - WITH MY ANSWERS OR REQUESTS FOR MORE DATA RELATED TO EACH ITEM. BECAUSE THE MORE WE WORK TOGETHER, THE MORE I UNDERSTAND YOUR REQUIREMENTS ARE DIFFERENT, I ASKED FOR SOME DETAILED INFO. IF YOU DO NOT KNOW WHAT PANELS YOU'LL BE USING, YOU MAY GO WITH YOUR BEST GUESS OR JUST LET ME KNOW.

THE 2-ND DOCUMENT IN THIS FAX IS AN ANALYSIS OF 24 bpp MODES BASED ON THE LATEST DATA I GOT. IN THE MEETING WE TOSSED SOME

IDEAS AROUND, BUT AFTER SOME THOUGHT OVER THE WEEKEND, I THINK I KNOW HOW TO DO THE CONVERSION FROM APPLE FORMAT TO A MORE MEMORY EFFICIENT FORMAT - WITHOUT SW INTERVENTION (EXCEPT FOR A SET-MODE ROUTINE). I'D LIKE YOUR FEED-BACK ON THE IDEAS EXPRESSED IN THIS DOCUMENT.

I HAVE A QUESTION: IF I ADD 20% TO 832, AS WELL AS 624 I GET 998.4 AND 748.8. NOW  $998.4 \times 748.8 \times 68.7 = 51.36 \text{ MHz}$  DOT-CLOCK FREQUENCY. HOW DO YOU GET 57.28MHz? IS NON-DISPLAY TIME MORE THAN 20% OR THE REFRESH RATE 75Hz?

Best Regards,

Vlad Bril

Cirrus Confidential  
Business Information

CL 157379

DO NOT COPY - FAX 3400000

# Memo

TO: Brian Howard and Mary Johnson of Apple Computer, Inc.  
FROM: Vlad Bril of Cirrus Logic, Inc.  
DATE: 01/22/94  
RE: Apple's Specification - Engineering Issues  
CC: Dennis Jow, Peter Pernice, Guido Carasso, Del Mank

Here is a summary of the meeting we had with some questions.  
I marked what Nordic can do relative to the specification you wrote on the board.  
In some cases the description is not detailed enough for me to give an answer.

Apple Spec from Brian:

What Nordic supports:

|                                                                                                                   |                                                                                                                                      |
|-------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|
| PCI Bus                                                                                                           | yes                                                                                                                                  |
| LCD 640x480 16bpp                                                                                                 | probably yes but I need:<br>What kind of Panels?<br>Dot-clock?<br>What Refresh Rate?                                                 |
| CRT 640x480 16bpp @ 30.24MHz, 67Hz                                                                                | yes                                                                                                                                  |
| 832x624 8bpp @ 57.2832MHz, 68.7Hz                                                                                 | yes                                                                                                                                  |
| Mirror Mode 640x480x8bpp LCD & CRT                                                                                | Probably yes but I need:<br>What panels?<br>What dot-clock?<br>Is it 67Hz refresh?<br>Dual Scan STN Panels may require fast drivers. |
| Big Endian memory space for frame buffer                                                                          | yes                                                                                                                                  |
| 1,4,8,16 bpp packed modes                                                                                         | yes                                                                                                                                  |
| April '94 prototypes<br>July '94 EVD2 (production quality silicon)<br>Jan '95 production ramp<br>March '95 Intro. |                                                                                                                                      |

Cirrus Confidential  
Business Information

CL 157380

Brian's Wish List:

800x600 16bpp on panels

832x624 16bpp on CRT

640x480 16bpp both screens

800x600 16bpp LCD & 832x624 16bpp CRT

2bpp packed

\$20 price @ 20-30K/mo

What Nordic supports:

yes on TFT & DS STN panels  
@ 40MHz dot-clock, 60Hz  
refresh rate

no (not @ 57.3MHz)

Probably Yes, but I need  
data on panels, dot-clock  
refresh rate.

no - mem. bandwidth probl.  
(not at 57.2MHz dot-clock  
can run only upto 40MHz)

may deliver by July if  
required, not in current rev.

CIRRUS LOGIC INC.

Cirrus Confidential  
Business Information

CL 157381

# Memo

---

TO: Brian Howard and Mary Johnson of Apple Computer, Inc.  
FROM: Vlad Bril of Cirrus Logic, Inc.  
DATE: 01/22/94  
RE: Apple's 24bpp Graphics Modes  
CC: Dennis Jow, Peter Pernice, Guido Carasso, Del Mank

---

## Summary

In the Jan. 21-st '94 meeting Brian presented us with a request for future support of Apple 24bpp mode. This document outlines the problems and the possible related solutions. The conclusion is that it is possible to run Apple's 24bpp mode in a system with a 32bit wide DRAM-based Frame Buffer at 25MHz dot-clock and even 31MHz dot-clock.

A for 834x624 at 57.3MHz dot-clock, the Frame Buffer should be 64bits wide and similar solution will work.

This document represents a technical analysis; it is not a commitment from Cirrus Logic to implement these features as described.

This document should be kept confidential under our Non-Disclosure Agreement.

## Analysis of Memory Bandwidth Requirements

Given the fact that the fastest 256Kx16 DRAM available today has a page cycle (TPC) of 40ns and a random cycle of about 130ns, is it possible to run Apple's 24bpp + alpha mode at 25MHz (60Hz refresh) without reformatting the data in memory?

As one memory fetch (32bits) represents one pixel, and each pixel is fetched every 40ns, the average memory fetch cycle time (assuming a mix of random and paged cycles) should be less than 40ns, in order to execute some CPU cycles too.

With a TPC of 40ns (equal to the time a pixel is displayed) this is impossible.

Assuming a large CRT-FIFO that ensures 16 CRT memory fetches in a row, what is the maximum dot-clock frequency this could work at?

R+15P = 7m+30m = 37m = 740ns to fetch 16 pixels -> 21.6MHz dot-clock.

With a controller that can run a TFT panel with almost no non-display time, this may still provide 60Hz refresh rate, but the CPU performance will be low.

To get a decent CPU performance, we should execute at least one CPU cycle every FIFO fill, which leads to:

R+R+15P=44m=880ns to fetch 16 pixels -> 18.2MHz dot-clock which will reduce the refresh rate to about 55Hz even with no non-display time.

To run an 834x624 24bpp + alpha channel mode at 57.3MHz the requirements are even more difficult to meet: an average memory cycle should be 17.4ns, much below even the future Extended Data Out -60 256Kx16 DRAM-s (best TPC is 25ns).

Cirrus Confidential  
Business Information

CL 157382

**Solution for 640x480 mode at 25 MHz**

The proposed solution is to reformat the data in memory by eliminating the alpha channel. This should be done fully transparent to the CPU. This will increase memory bandwidth by 25%.

This solution was talked about in the meeting, but it was not obvious how data reformatting can be done in a transparent way to CPU.

The solution proposed here is not trivial to implement, but it is possible. I'd rank the design complexity as average.

The idea is to remap the data to and from frame-buffer memory based on the CPU Address bits 3 and 2. Each possible combination of these two bits will require a different way of accessing the memory in terms of number of memory accesses, memory address and bytes enabled for access. The result is represented in the following figure:



With this approach, the minimum memory clock frequency to run 640x480 at 25MHz deadlock is 44MHz, while an optimum frequency is 52.5MHz.

With this CPU Data reformatting approach it is possible to run 640x480 24bpp at about 25MHz dot-clock with 256Kx16 -70 DRAM-s with Page Cycle of 40ns. The performance is close to optimum.

Cirrus Confidential  
Business Information

MEMO

---

To run the same mode at 31MHz dot-clock, though the minimum memory clock frequency is 54MHz, the optimum is 65MHz requiring a page mode cycle time of 37ns and 30ns respectively and a -70 or -60 Extended Data Out DRAM.

These calculations assume a reformatted 24bpp memory format.

**Solution for 834x624 at 57.3MHz**

At 24bpp this mode requires 1.5MB of memory anyway. The optimum way to run it is with 2MB of memory 64bits wide.

Even with 64bit wide DRAM you'd need a 13ns TPC to run this mode in the standard Apple format in an optimum way (15ns TPC minimum).

If the data is reformatted by removing the alpha channel, with a large CRT-FIFO you can get to a minimum of memory clock frequency of 50MHz and an optimum of 60MHz, which is well within reach with a -70 or -60 EDO DRAM.

The design of the reformatting circuitry for 64bit wide memory is more complex than for 32bit wide memory because it requires more cases to be covered.

90005472 - 20131000

Cirrus Confidential  
Business Information

**CL 157384**

**This Page is Inserted by IFW Indexing and Scanning  
Operations and is not part of the Official Record**

**BEST AVAILABLE IMAGES**

Defective images within this document are accurate representations of the original documents submitted by the applicant.

Defects in the images include but are not limited to the items checked:

- BLACK BORDERS**
- IMAGE CUT OFF AT TOP, BOTTOM OR SIDES**
- FADED TEXT OR DRAWING**
- BLURRED OR ILLEGIBLE TEXT OR DRAWING**
- SKEWED/SLANTED IMAGES**
- COLOR OR BLACK AND WHITE PHOTOGRAPHS**
- GRAY SCALE DOCUMENTS**
- LINES OR MARKS ON ORIGINAL DOCUMENT**
- REFERENCE(S) OR EXHIBIT(S) SUBMITTED ARE POOR QUALITY**
- OTHER:** \_\_\_\_\_

**IMAGES ARE BEST AVAILABLE COPY.**

As rescanning these documents will not correct the image problems checked, please do not report these problems to the IFW Image Problem Mailbox.